工作常用SQL
https://www.518cn.com 发布时间:2025-03-18 22:26 作者:网络
摘要:工作常用SQL Excel生成SQL 这个好用 =insert into t_gk_mapping(id,gk_project_name,gk_project_code,main_project_name,main_project_code) values (&am
为
工作常用SQL
Excel生成SQL
这个好用
="insert into t_gk_mapping(id,gk_project_name,gk_project_code,main_project_name,main_project_code) values ('"&J2&"','"&I2&"','"&K2&"','"&L2&"','"&M2&"');"
为某个表加入字段
ALTER TABLE `表名` ADD `字段名` 字段类型 COMMENT '描述';
为name
字段拼接 值
update user set name = concat(name,'test') where 1=1
REPLACE()字符串函数 替换函数
UPDATE
student
SET
name = REPLACE(name,'小明','小红')
WHERE
id = '1';
关联表,将匹配到的数据另一个表的字段set到当前表字段中
update t1,t2 set t1.`name` = t2.class_name where t1.id = t2.id
将表中一个字段的值更新为另一个字段的值 (自连接)
update student a,student b set a.name = b.class
where a.id = b.id
根据number删除重复记录,保留code较小的数据
delete from t1 where id in
(
select * from
(select id from t1
where number in (select number from t1 group by number
having count(number) > 1)
and code not in (select min(code) from t1 group by number having
count(number)>1)
) as a)
去除某个字段前后空格
在MySQL中,如果你想要删除某个字段的前后空格,你可以使用
TRIM()
函数。TRIM()
函数用于删除字符串的前导和尾随空格。
UPDATE current_transactions_count
SET communication_subject = TRIM(communication_subject);
去除某个字段中的换行
UPDATE users
SET description = REPLACE(description, 'n', '');
行列转换
select
unitName as unitName,
MAX(CASE WHEN management_objects = 'a' THEN count END) AS a,
MAX(CASE WHEN management_objects = 'b' THEN count END) AS b,
MAX(CASE WHEN management_objects = 'c' THEN count END) AS c
from
project
group by unitName
将子表多条数据的某些字段提到副表某个字段上
如果你需要将副表中的两个字段拼接,并且当存在多个相关记录时,这些拼接后的字符串之间用逗号分隔,你可以使用GROUP_CONCAT
函数来同时拼接这两个字段,并在它们之间使用一个自定义的分隔符(例如一个空格或者没有分隔符)。
假设你的sub_table
有两个字段field1
和field2
,你想要将它们拼接起来,并且对于main_table
中的每一行,所有相关的sub_table
行都会被拼接并且用逗号分隔,你可以这样做:
SELECT
main_table.*,
(
SELECT GROUP_CONCAT(CONCAT(sub_table.field1, ' ', sub_table.field2) SEPARATOR ', ')
FROM sub_table
WHERE sub_table.id = main_table.id
) AS concatenated_values
FROM main_table;
在这个查询中,CONCAT(sub_table.field1, ' ', sub_table.field2)
负责将field1
和field2
字段的值拼接起来,并在它们之间插入一个空格(如果你不需要空格,可以去掉它)。然后,GROUP_CONCAT(... SEPARATOR ', ')
将这些拼接后的字符串用逗号和一个空格分隔开。
相关文章
- 优化GreatSQL日志文件空间占用 GreatSQL对于日志文件磁盘空间占用,做了一些优化,对于binlog、...03-18
- "数据约束条件" date: 2022-11-24T21:24:31 08:00 draft: false MySQL字段约束条件 无符号, 零填充...03-18
【GreatSQL优化器-16】INDEX_SKIP_SCAN
【GreatSQL优化器-16】INDEX_SKIP_SCAN 一、INDEX_SKIP_SCAN介绍 GreatSQL 优化器的索引跳跃扫描(Index Ski...03-18- MySQL 是一个非常流行的开源关系数据库管理系统,在各种应用场景中都得到了广泛的应用。随...03-18
- 🤖 DB-GPT 是一个开源的 AI 原生数据应用程序开发框架,具有 AWEL(代理工作流表达式语...03-18
GreatSQL 8.0.32-27 GA (2025-3-10)
GreatSQL 8.0.32-27 GA (2025-3-10) 版本信息 发布时间:2025年3月10日 版本号:8.0.32-27, Revision aa66a38591...03-18- 6. MySQL 索引的数据结构(详细说明) @目录6. MySQL 索引的数据结构(详细说明)1. 为什么使用索引2...03-18
- @Override @Transactional(rollbackFor = Exception.class) public void batchInsertDeviceData(IotMsgNotifyData iotMsgNotifyDa...03-18
- 个人Qt项目总结——数据库查询断言问题 问题: 当我使用MySQL数据库的查询操作时, 如果查询...03-18
- MySQL 是一种广泛使用的关系数据库管理系统,MySQL 8 是其最新的主要版本,结合了出色的性能和...03-18
最新评论