不少开发人员会用到concat函数,本文针对mysql和oracle场景下,concat函数的使用差异做如下总结:
一、函数的使用参数不同
MySQL支持多个字符串拼接:
CONCAT(str1,str2,…)
Oralce只支持两个字符串的拼接,若想拼接多个字符串可以嵌套使用concat
CONCAT(CONCAT(str1,str2),str3)
二、参数中有Null的处理方式不同
MySQL:返回结果为连接参数产生的字符串。如有任何一个参数为NULL ,则返回值为 NULL。
Oralce:如有任何一个参数为NULL ,则返回值拼接后的字符串。
三、二进制字符串转换不同
MySQL:不会主动返回非二进制字符串
只有所有参数均为非二进制字符串,结果才为非二进制字符串。
如果自变量中含有任一二进制字符串,则结果为一个二进制字符串。
Oracle:主动返回字符串。
如果CONCAT中连接的值不是字符串,Oracle会尝试将其转换为字符串