我想替换(或删除)TSQL-string中的换行符。 什么好主意吗?

最明显的

REPLACE(@string, CHAR(13), '')

就是不去做……


当前回答

REPLACE(@string, CHAR(13) + CHAR(10), '')

其他回答

REPLACE(@string, CHAR(13) + CHAR(10), '')

T-SQL中的换行符由CHAR(13) & CHAR(10)(回车+换行)表示。因此,可以使用要替换换行符的文本创建REPLACE语句。

REPLACE(MyField, CHAR(13) + CHAR(10), 'something else')

实际上,SQL命令或脚本字符串中的新行可以是CR、LF或CR+LF中的任意一个。要得到所有这些,你需要这样的东西:

SELECT REPLACE(REPLACE(@str, CHAR(13), ''), CHAR(10), '')

上面/之前发布的答案被报道为取代CHAR(13)CHAR(10)回车:

REPLACE(REPLACE(REPLACE(MyField, CHAR(13) + CHAR(10), 'something else'), CHAR(13), 'something else'), CHAR(10), 'something else')

永远不会到达代码的REPLACE(MyField, CHAR(13) + CHAR(10), 'something else')部分,并将返回不需要的结果:

'something else''something else'

而不是单一的理想结果:

'something else'

这将需要REPLACE脚本重写如下:

REPLACE(REPLACE(REPLACE(MyField, CHAR(10), 'something else'), CHAR(13), 'something else'), CHAR(13) + CHAR(10), 'something else')

当流首先测试第一个/最左边的REPLACE语句时,如果失败,将继续测试下一个REPLACE语句。

到@Cerebrus解决方案:对于字符串“+”的H2不支持。所以:

REPLACE(string, CHAR(13) || CHAR(10), 'replacementString')