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

最明显的

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

就是不去做……


当前回答

如果你有一个问题,你只想删除尾随字符,你可以试试这个:

WHILE EXISTS
(SELECT * FROM @ReportSet WHERE
    ASCII(right(addr_3,1)) = 10
    OR ASCII(right(addr_3,1)) = 13
    OR ASCII(right(addr_3,1)) = 32)
BEGIN
    UPDATE @ReportSet
    SET addr_3 = LEFT(addr_3,LEN(addr_3)-1)
    WHERE 
    ASCII(right(addr_3,1)) = 10
    OR ASCII(right(addr_3,1)) = 13
    OR ASCII(right(addr_3,1)) = 32
END

这解决了我在地址方面遇到的一个问题,其中一个过程创建了一个具有固定行数的字段,即使这些行是空的。为了节省SSRS报告的空间,我把它们剪掉了。

其他回答

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), '')

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

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

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

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

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

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