关于这个话题,我没有看到任何类似的问题,我必须为我现在正在做的事情研究这个问题。我想我应该把答案贴出来以防其他人也有同样的问题。


当前回答

char(13)是CR。对于DOS-/ windows风格的CRLF换行符,你需要char(13)+char(10),像这样:

'This is line 1.' + CHAR(13)+CHAR(10) + 'This is line 2.'

其他回答

这总是很酷的,因为当您从Oracle获得导出列表时,您将获得跨越几行的记录,这对于cvs文件来说可能很有趣,所以要小心。

无论如何,Rob的答案很好,但我建议使用其他的东西,而不是@,尝试更多的东西,比如§§@@§§或其他的东西,这样它就有一些独特性的机会。(但是仍然要记住你插入的varchar/nvarchar字段的长度..)

跟着谷歌…

从网站上获取代码:

CREATE TABLE CRLF
    (
        col1 VARCHAR(1000)
    )

INSERT CRLF SELECT 'The quick brown@'
INSERT CRLF SELECT 'fox @jumped'
INSERT CRLF SELECT '@over the '
INSERT CRLF SELECT 'log@'

SELECT col1 FROM CRLF

Returns:

col1
-----------------
The quick brown@
fox @jumped
@over the
log@

(4 row(s) affected)


UPDATE CRLF
SET col1 = REPLACE(col1, '@', CHAR(13))

看起来可以通过用CHAR(13)替换占位符来完成。

问得好,我自己从来没做过:)

另一种方法是:

INSERT CRLF SELECT 'fox 
jumped'

也就是说,在编写查询时只需在查询中插入一个换行符,就可以将类似的换行符添加到数据库中。这在SQL server管理工作室和查询分析器中工作。我相信如果你在字符串上使用@符号,这在c#中也可以工作。

string str = @"INSERT CRLF SELECT 'fox 
    jumped'"

所有这些选项都可以工作,这取决于您的情况,但如果您使用SSMS(正如在一些评论中提到的SSMS隐藏CR/ lf),您可能看不到它们中的任何一个工作。

所以,与其开车去拐弯,不如检查一下这个设置

工具|选项

我想说的

concat('This is line 1.', 0xd0a, 'This is line 2.')

or

concat(N'This is line 1.', 0xd000a, N'This is line 2.')