CONCAT函数将所有非NULL参数按顺序拼接,任一参数为NULL则结果为NULL;支持任意数量参数,自动隐式转字符串,但需用CONCAT_WS或IFNULL/COALESCE处理NULL以避免空结果。
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会导致大量空结果。推荐两种解法:
CONCAT_WS(' ', first_name, middle_name, last_name):第一个参数是分隔符,自动跳过NULL值,只拼非空部分CONCAT(IFNULL(first_name, ''), ' ', IFNULL(last_name, '')),更可控,但写起来略长CONCAT_WS的分隔符只插在非NULL值之间,不会出现在开头或结尾CONCAT()在 MySQL/MariaDB 中行为一致,但其他数据库不认这个函数名:
|| 操作符:first_name || ' ' || last_name
+:first_name + ' ' + last_name(但NULL + anything = NULL,同样要ISNULL()处理)CONCAT(),但其实是||的别名,底层还是用连接符||(需确认目标库是否支持)或改用COALESCE组合拼接本身开销很小,但要注意两点:
WHERE里用CONCAT查字段(比如WHERE CONCAT(first_name, last_name) = 'JohnDoe')会无法走索引,全表扫描风险高IF()或CASE难维护CONCAT嵌套着写,比如CONCAT(CONCAT(a,b), CONCAT(c,d)),直接平铺更清晰真正麻烦的是字段类型混合(比如INT和VARCHAR混拼)加NULL判断再加跨库适配——这时候不如先确认业务到底需要拼什么、在哪用、谁来消费结果。