如何在SQL Server VARCHAR/NVARCHAR字符串中插入换行符

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

1307194 次浏览

我在这里找到了答案:http://blog.sqlauthority.com/2007/08/22/sql-server-t-sql-script-to-insert-carriage-return-and-new-line-feed-in-code/

您只需连接字符串并在需要换行符的位置插入CHAR(13)

例子:

DECLARE @text NVARCHAR(100)
SET @text = 'This is line 1.' + CHAR(13) + 'This is line 2.'
SELECT @text

这将打印出以下内容:

这是第一行
这是第二行

遵循谷歌

从网站上获取代码:

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)替换占位符来完成

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

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字段的长度。)

另一种方法是:

INSERT CRLF SELECT 'fox
jumped'

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

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

下面是一个c#函数,它在现有文本blob前加上一个文本行,由crlf分隔,并返回适合于INSERTUPDATE操作的T-SQL表达式。它有一些我们专有的错误处理,但一旦你把它去掉,它可能会有帮助,我希望如此。

/// <summary>
/// Generate a SQL string value expression suitable for INSERT/UPDATE operations that prepends
/// the specified line to an existing block of text, assumed to have \r\n delimiters, and
/// truncate at a maximum length.
/// </summary>
/// <param name="sNewLine">Single text line to be prepended to existing text</param>
/// <param name="sOrigLines">Current text value; assumed to be CRLF-delimited</param>
/// <param name="iMaxLen">Integer field length</param>
/// <returns>String: SQL string expression suitable for INSERT/UPDATE operations.  Empty on error.</returns>
private string PrependCommentLine(string sNewLine, String sOrigLines, int iMaxLen)
{
String fn = MethodBase.GetCurrentMethod().Name;


try
{
String [] line_array = sOrigLines.Split("\r\n".ToCharArray());
List<string> orig_lines = new List<string>();
foreach(String orig_line in line_array)
{
if (!String.IsNullOrEmpty(orig_line))
{
orig_lines.Add(orig_line);
}
} // end foreach(original line)


String final_comments = "'" + sNewLine + "' + CHAR(13) + CHAR(10) ";
int cum_length = sNewLine.Length + 2;
foreach(String orig_line in orig_lines)
{
String curline = orig_line;
if (cum_length >= iMaxLen) break;                // stop appending if we're already over
if ((cum_length+orig_line.Length+2)>=iMaxLen)    // If this one will push us over, truncate and warn:
{
Util.HandleAppErr(this, fn, "Truncating comments: " + orig_line);
curline = orig_line.Substring(0, iMaxLen - (cum_length + 3));
}
final_comments += " + '" + curline + "' + CHAR(13) + CHAR(10) \r\n";
cum_length += orig_line.Length + 2;
} // end foreach(second pass on original lines)


return(final_comments);




} // end main try()
catch(Exception exc)
{
Util.HandleExc(this,fn,exc);
return("");
}
}

我来这里是因为我担心我在c#字符串中指定的cr-lfs没有在SQl Server Management Studio查询响应中显示。

事实证明,它们确实存在,但没有被展示出来。

要“查看”cr-lfs,使用如下的打印语句:

declare @tmp varchar(500)
select @tmp = msgbody from emailssentlog where id=6769;
print @tmp

在SSMS中运行这个,它显示了SQL中的换行符本身是如何成为字符串值的一部分的:

PRINT 'Line 1
Line 2
Line 3'
PRINT ''


PRINT 'How long is a blank line feed?'
PRINT LEN('
')
PRINT ''


PRINT 'What are the ASCII values?'
PRINT ASCII(SUBSTRING('
',1,1))
PRINT ASCII(SUBSTRING('
',2,1))
< p >结果:< br > 1号线< br > 第2行< br > 第3行

空换行有多长?< br > 2 < / p >

ASCII值是什么?< br > 13 < br > 10 < / p >

或者如果你更愿意在一行中指定你的字符串(几乎!),你可以像这样使用REPLACE()(可以选择使用CHAR(13)+CHAR(10)作为替换):

PRINT REPLACE('Line 1`Line 2`Line 3','`','
')

我想说的

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

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

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

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

# eyz0 # eyz1 # eyz2

# EYZ0

在某些特殊情况下,你可能会发现这很有用(例如在MS Report中渲染cell-content)
例子:

select * from
(
values
('use STAGING'),
('go'),
('EXEC sp_MSforeachtable
@command1=''select ''''?'''' as tablename,count(1) as anzahl from  ? having count(1) = 0''')
) as t([Copy_and_execute_this_statement])
go