テーブル「デバイス」に次のデータがあります
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)
NULLを無視するようにこれから抜け出す方法と結果は
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-
NULL
をラップして、COALESCE
の値を空の文字列に変換します
SELECT CONCAT(COALESCE(`affiliate_name`,''),'-',COALESCE(`model`,''),'-',COALESCE(`ip`,''),'-',COALESCE(`os_type`,''),'-',COALESCE(`os_version`,'')) AS device_name
FROM devices
代わりに CONCAT_WS を使用してください:
CONCAT_WS()は空の文字列をスキップしません。ただし、セパレーター引数の後のNULL値はスキップします。
SELECT CONCAT_WS('-',`affiliate_name`,`model`,`ip`,`os_type`,`os_version`) AS device_name FROM devices
SELECT CONCAT(isnull(`affiliate_name`,''),'-',isnull(`model`,''),'-',isnull(`ip`,''),'-',isnull(`os_type`,''),'-',isnull(`os_version`,'')) AS device_name
FROM devices
CONCAT_WSとCONCAT_WSで同じ柔軟性を得るには(たとえば、すべてのメンバー間で同じセパレーターが必要ない場合)、次を使用します。
SELECT CONCAT_WS("",affiliate_name,':',model,'-',ip,... etc)
最初のフィールドがNullの場合、CONCAT_WS
は引き続きnullを生成します。私はこれを解決するために、最初にゼロの長さの文字列を追加しました
CONCAT_WS("",`affiliate_name`,'-',`model`,'-',`ip`,'-',`os_type`,'-',`os_version`)
しかしながら
CONCAT("",`affiliate_name`,'-',`model`,'-',`ip`,'-',`os_type`,'-',`os_version`)
最初のフィールドがNullの場合、Nullを生成します。
以下のようなifステートメントを使用できます
select CONCAT(if(affiliate_name is null ,'',affiliate_name),'- ',if(model is null ,'',affiliate_name)) as model from devices