您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“MySQL中CONCAT()函數拼接出現NULL問題如何解決”,內容詳細,步驟清晰,細節處理妥當,希望這篇“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
讀到這里,這篇“MySQL中CONCAT()函數拼接出現NULL問題如何解決”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。