MySQL中CONCAT()函数拼接出现NULL的问题
项目中查询用到了concat()拼接函数,在此查询中出现了拼接的字段为null的情况,拼接结果为null在应用层报了空指针异常。
SELECT CONCAT('1,',NULL,'2') result;
SELECT CONCAT('1,','','2') result;
通过实践证明CONCAT()函数拼接时如果拼接的参数中有NULL时,结果为NULL。
使用以下方式来解决
方法一:使用IFNULL函数如果是NULL将其置为''空字符串。
SELECT CONCAT('1,',IFNULL(NULL,''),'2') result;
方法二:使用CONCAT_WS函数。指定有分隔符的字符串连接
SELECT CONCAT_WS(',','1',NULL,'2') result;
指定使用逗号进行分隔
CONCAT_WS(分隔符,参数1,参数2,...参数n)与CONCAT(参数1,参数2,...参数n)
两个函数的区别:
CONCAT_WS():表示concat with separator,即有分隔符的字符串连接
CONCAT():表示将字符串进行连接
两个最重要的区别就是,CONCAT()函数,拼接参数中存在NULL直接返回NULL
而CONCAT_WS()函数在执行的时候,不会因为NULL值而返回NULL
分类:
DataBase
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通