最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
SQL查询中如何使用CONCAT函数将多个列的数据拼接成一个字符串?
时间:2026-06-19 09:06:46 编辑:袖梨 来源:一聚教程网
CONCAT函数将所有非NULL参数按顺序拼接,任一参数为NULL则结果为NULL;支持任意数量参数,自动隐式转字符串,但需用CONCAT_WS或IFNULL/COALESCE处理NULL以避免空结果。
CONCAT函数的基本用法和参数要求
MySQL 5.0.22+ 和 MariaDB 支持 CONCAT(),它把所有非NULL参数按顺序拼接,遇到NULL直接返回NULL。这点特别容易踩坑——哪怕只有一个字段是NULL,整条结果就空了。
-
CONCAT('a', 'b', 'c')→'abc' -
CONCAT(first_name, ' ', last_name)→ 如果first_name为NULL,结果就是NULL,不是' NULL' - 参数个数不限,但每个都必须是字符串类型或能隐式转成字符串的值(比如数字会转成字符)
处理NULL值:用CONCAT_WS或IFNULL兜底
实际查表时,姓名、地址等字段常含NULL,直接CONCAT会导致大量空结果。推荐两种解法:
- 用
CONCAT_WS(' ', first_name, middle_name, last_name):第一个参数是分隔符,自动跳过NULL值,只拼非空部分 - 显式补空:
CONCAT(IFNULL(first_name, ''), ' ', IFNULL(last_name, '')),更可控,但写起来略长 - 注意:
CONCAT_WS的分隔符只插在非NULL值之间,不会出现在开头或结尾
不同数据库的兼容性差异
CONCAT()在 MySQL/MariaDB 中行为一致,但其他数据库不认这个函数名:
- PostgreSQL 用
||操作符:first_name || ' ' || last_name - SQL Server 用
+:first_name + ' ' + last_name(但NULL + anything = NULL,同样要ISNULL()处理) - SQLite 也支持
CONCAT(),但其实是||的别名,底层还是用连接符 - 如果写跨库SQL,优先考虑标准写法
||(需确认目标库是否支持)或改用COALESCE组合
性能和可读性提醒
拼接本身开销很小,但要注意两点:
- 在
WHERE里用CONCAT查字段(比如WHERE CONCAT(first_name, last_name) = 'JohnDoe')会无法走索引,全表扫描风险高 - 复杂拼接建议抽到应用层做,尤其是带条件逻辑(如“有middle_name才加空格”),SQL里嵌套太多
IF()或CASE难维护 - 别为了省一行代码把多个
CONCAT嵌套着写,比如CONCAT(CONCAT(a,b), CONCAT(c,d)),直接平铺更清晰
真正麻烦的是字段类型混合(比如INT和VARCHAR混拼)加NULL判断再加跨库适配——这时候不如先确认业务到底需要拼什么、在哪用、谁来消费结果。