工作常用SQL

玛卡巴卡的卡巴卡玛  论坛元老 | 2024-7-26 18:36:26 | 来自手机 | 显示全部楼层 | 阅读模式
打印 上一主题 下一主题

主题 1678|帖子 1678|积分 5034

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?立即注册

x
工作常用SQL

Excel生成SQL

这个好用
  1. ="insert into t_gk_mapping(id,gk_project_name,gk_project_code,main_project_name,main_project_code) values ('"&J2&"','"&I2&"','"&K2&"','"&L2&"','"&M2&"');"
复制代码
为name字段拼接 值
  1. update user set name = concat(name,'test') where 1=1
复制代码
REPLACE()字符串函数  更换函数
  1. UPDATE
  2.         student
  3. SET
  4.         name = REPLACE(name,'小明','小红')
  5. WHERE
  6.         id = '1';
复制代码
关联表,将匹配到的数据另一个表的字段set到当前表字段中
  1. update t1,t2 set t1.`name` = t2.class_name where t1.id = t2.id
复制代码
将表中一个字段的值更新为另一个字段的值 (自连接)
  1. update student a,student b set a.name = b.class
  2. where a.id = b.id
复制代码
根据number删除重复记录,保留code较小的数据
  1. delete from t1 where id in
  2. (
  3. select * from
  4. (select id from t1
  5. where number  in (select  number  from t1  group  by  number   
  6. having  count(number) > 1)
  7. and code not in (select min(code) from  t1  group by number  having
  8. count(number)>1)
  9. ) as a)
复制代码
去除某个字段前后空格

在MySQL中,如果你想要删除某个字段的前后空格,你可以使用TRIM()函数。TRIM()函数用于删除字符串的前导和尾随空格。
  1. UPDATE current_transactions_count  
  2. SET communication_subject = TRIM(communication_subject);
复制代码
去除某个字段中的换行
  1. UPDATE users
  2. SET description = REPLACE(description, '\n', '');
复制代码
行列转换
  1. select
  2. unitName as unitName,
  3. MAX(CASE WHEN management_objects = 'a' THEN count  END) AS a,
  4. MAX(CASE WHEN management_objects = 'b' THEN count END) AS b,
  5. MAX(CASE WHEN management_objects = 'c' THEN count  END) AS c
  6. from
  7.         project
  8. group by unitName
复制代码
将子表多条数据的某些字段提到副表某个字段上

如果你需要将副表中的两个字段拼接,而且当存在多个相关记录时,这些拼接后的字符串之间用逗号分隔,你可以使用GROUP_CONCAT函数来同时拼接这两个字段,并在它们之间使用一个自定义的分隔符(例如一个空格大概没有分隔符)。
假设你的sub_table有两个字段field1和field2,你想要将它们拼接起来,而且对于main_table中的每一行,所有相关的sub_table行都会被拼接而且用逗号分隔,你可以这样做:
  1. SELECT   
  2.     main_table.*,  
  3.     (  
  4.         SELECT GROUP_CONCAT(CONCAT(sub_table.field1, ' ', sub_table.field2) SEPARATOR ', ')  
  5.         FROM sub_table  
  6.         WHERE sub_table.id = main_table.id  
  7.     ) AS concatenated_values  
  8. FROM main_table;
复制代码
在这个查询中,CONCAT(sub_table.field1, ' ', sub_table.field2)负责将field1和field2字段的值拼接起来,并在它们之间插入一个空格(如果你不需要空格,可以去掉它)。然后,GROUP_CONCAT(... SEPARATOR ', ')将这些拼接后的字符串用逗号和一个空格分隔开。

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

正序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

玛卡巴卡的卡巴卡玛

论坛元老
这个人很懒什么都没写!
快速回复 返回顶部 返回列表