我遇到的问题是,varchar
如果值包含CR/LF
值(不是尾随),则不会正确返回 a 的长度。
例如以下查询片段:
数据类似于:
<xml><name>Name[CR/LF] Name</name></xml>
像这样的查询:
DECLARE @myid as INT
DECLARE @xmldata as VARCHAR(8000)
SET @myid = 1
SELECT @xmldata = xmldata FROM mytable WHERE id=@myid
PRINT 'The length is ' + CAST(LEN(@xmldata) AS VARCHAR(6))
PRINT 'Data:'
PRINT @xmldata
将输出:
The length is 15
Data:
<xml><name>Name[CR/LF] Name</name></xml>
我希望 LEN 函数返回 35 作为长度?
这是在 SQL Server 2000 SP4 (8.00.2065) 上
有谁知道是否有设置或其他功能可以用来防止这种情况。我能想到的一个选项是删除选择中的回车符和换行符:
SELECT @xmldata = REPLACE(REPLACE(REPLACE(REPLACE(xmldata, CHAR(13) + CHAR(10), ''), CHAR(10) + CHAR(13), ''), CHAR(13), ''), CHAR(10), '')
但希望可能有另一个功能或设置来覆盖该行为。