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

最明显的

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

就是不去做……


当前回答

我想清除一个列的内容,以生成一个csv文件,所以想摆脱逗号(,)在varchar以及换行符和回车。

我还想最终使用生成的csv来创建另一个脚本(将行插入到另一个db中),所以也需要在varchar中更改为“因此最终得到了这个…

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

也许还有其他更好的方法,但它已经完成了任务。

其他回答

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

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(myString, CHAR(13) + CHAR(10), ' ')

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

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

如果您的列数据类型是'text',那么您将得到一个错误消息为

Msg 8116,级别16,状态1,第2行参数数据类型文本是 replace函数的参数1无效。

在这种情况下,您需要将文本转换为nvarchar,然后进行替换

SELECT REPLACE(REPLACE(cast(@str as nvarchar(max)), 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语句。