ホームページ >データベース >mysql チュートリアル >MySQL で文字列を連結するときに NULL 値を処理する方法は?

MySQL で文字列を連結するときに NULL 値を処理する方法は?

Susan Sarandon
Susan Sarandonオリジナル
2025-01-05 04:58:10483ブラウズ

How to Handle NULL Values When Concatenating Strings in MySQL?

MySQL CONCAT での NULL 値の処理

CONCAT() 関数を使用して MySQL の複数のフィールドを連結すると、結果が次のようになる可能性があります。いずれかのフィールドに NULL 値が含まれている場合は NULL。これにより、データ取得操作で予期しない結果が生じる可能性があります。

「デバイス」テーブル内の次のデータを考慮してください:

affiliate_name  affiliate_location  model     ip             os_type    os_version 
cs1             inter               Dell     10.125.103.25   Linux      Fedora  
cs2             inter               Dell     10.125.103.26   Linux      Fedora  
cs3             inter               Dell     10.125.103.27   NULL       NULL    
cs4             inter               Dell     10.125.103.28   NULL       NULL    

次のクエリを実行するとき:

SELECT CONCAT(`affiliate_name`,'-',`model`,'-',`ip`,'-',`os_type`,'-',`os_version`) AS device_name
FROM devices

次の結果が得られます:

cs1-Dell-10.125.103.25-Linux-Fedora
cs2-Dell-10.125.103.26-Linux-Fedora
(NULL)
(NULL)

ご覧のとおり、行os_type または os_version のいずれかに NULL が含まれているため、3 と 4 は NULL を返します。これを防ぐには、COALESCE() 関数を使用して、連結式の各フィールドをラップします。 COALESCE() は 2 つ以上の値を受け取り、最初の非 NULL 値を返すか、すべての値が NULL の場合は最後の引数を返します。

したがって、変更されたクエリは次のようになります。

SELECT CONCAT(COALESCE(`affiliate_name`,''),'-',COALESCE(`model`,''),'-',COALESCE(`ip`,''),'-',COALESCE(`os_type`,''),'-',COALESCE(`os_version`,'')) AS device_name
FROM devices

これ変更されたクエリは目的の結果を返すようになります:

cs1-Dell-10.125.103.25-Linux-Fedora
cs2-Dell-10.125.103.26-Linux-Fedora
cs3-Dell-10.125.103.27-
cs4-Dell-10.125.103.28-

各フィールドを COALESCE() でラップすることで、NULL 値が保証されます。は無視され、空の文字列に置き換えられ、NULL 以外の連結結果になります。

以上がMySQL で文字列を連結するときに NULL 値を処理する方法は?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。