PostgreSQL 中的条件字符串连接

J. *_*lor 8 postgresql null condition string concat

我有一个parcels当前包含列owner_addr1, owner_addr2,的表owner_addr3。有时,后两个字段中的一个或两个字段为空。我想将它们组合成一个新的字段,owner_addr上面的每个字段//都在它们之间连接。

但是如果一个或多个原始列是 NULL,我不想连接//到结果列。因此,举例来说,如果owner_addr1123 4th Avenue SEowner_addr2owner_addr3NULL,然后我想要的结果列只是123 4th Avenue SE,没有123 4th Avenue SE // //(如果我只是做了这会发生CONCAT()//空字符串之间......我只是想添加//非之间的NULL列,或将其如果只有一个非NULL列,则完全退出。

有没有一种简单的方法可以在 Postgresql 中进行这种条件连接,它会遗漏空行?或者我应该写一个python脚本来做到这一点?

ype*_*eᵀᴹ 14

该功能concat_ws()正是您想要的。第一个参数用作其余参数之间的粘合剂。空值被忽略:

select concat_ws('//', owner_addr1, owner_addr2, owner_addr3)
Run Code Online (Sandbox Code Playgroud)

测试:

red=# select concat_ws('//', 'abc', null, null, 'xx', null, 'xyz', null) 
          as address;
   address    
--------------
 abc//xx//xyz
(1 row)
Run Code Online (Sandbox Code Playgroud)