gpt4 book ai didi

sql - 使用分隔符连接或合并许多列值并忽略空值 - SQL Server 2016 或更早版本

转载 作者:行者123 更新时间:2023-12-04 01:07:37 25 4
gpt4 key购买 nike

我想用 SQL Server 2016 或更早版本模拟 CONCAT_WS SQL Server 2017+ 函数,以便连接许多值是字符串的列:

输入:

| COLUMN1 | COLUMN2 | COLUMN3 | COLUMN4 |
'A' 'B' NULL 'D'
NULL 'E' 'F' 'G'
NULL NULL NULL NULL

输出:

| MERGE |
'A|B|D'
'E|F|G'
NULL

请注意,输出结果是一个新列,它连接了由“|”分隔的所有值。如果列中没有值,则默认值应为 NULL。

我尝试使用 CONCAT 和带有许多 WHEN 条件的 CASE 语句,但确实很脏,我不允许使用此解决方案。提前致谢。

最佳答案

一种方便的方法是:

select stuff( coalesce(',' + column1, '') +
coalesce(',' + column2, '') +
coalesce(',' + column3, '') +
coalesce(',' + column4, ''), 1, 1, ''
)


关于sql - 使用分隔符连接或合并许多列值并忽略空值 - SQL Server 2016 或更早版本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65924066/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com