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

最明显的

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

就是不去做……


当前回答

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

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

其他回答

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

如果你已经使用sp_helptext打开程序,那么只需复制所有文本在新的sql查询和按ctrl+h按钮使用正则表达式替换,并把^\n在查找字段替换为空白。 欲了解更多细节,请检查图像。在这里输入图像描述

在SQL Server 2017及以后版本中,使用Trim

Select Trim(char(10) + char(13) from @str)

它注重开头和结尾,而不是中间部分 \r和\n的顺序无关紧要

我用它来修剪文件名的特殊字符

Select Trim(char(10) + char(13) + ' *<>' from @fileName)

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

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

有时

REPLACE(myString, CHAR(13) + CHAR(10), ' ')

不能工作。在这种情况下,使用以下片段代码:

REPLACE(REPLACE(myString, CHAR(13),''), CHAR(10), ' ')