有谁知道为什么这个
XML文本会在SQL Server 2008中抛出非法的名字符错误?
'<cs><c a="2" b="CITY & STATE TX" c="CITY & STATE TX"/></cs>'
异常消息是
Msg 9421,Level 16,State 1,Line 2 XML parsing: line 1,character 23,illegal name character
以下是用于解析此xml的查询
DECLARE @CaptionsDescriptions XML = '<cs><c a="2" b="CITY & STATE TX" c="CITY & STATE TX"/></cs>' DECLARE @DocHandle int DECLARE @CaptionsDescriptionsTable TABLE ( ID INT IDENTITY(1,1),languageID INT,Caption VARCHAR(50),Description VARCHAR(2000) ) EXEC sp_xml_preparedocument @DocHandle OUTPUT,@CaptionsDescriptions INSERT INTO @CaptionsDescriptionsTable SELECT a,b,c FROM OPENXML(@DocHandle,'cs/c') WITH ( a int,-- language id b varchar(50),-- caption c varchar(2000) -- description ) -- remove document handler EXEC sp_xml_removedocument @DocHandle
谢谢.
&是XML中的保留/特殊字符.它应该是& amp;
我甚至会添加XML解析:第1行,第23行,非法名称字符非常清楚.如果您认为SQL从1开始计数,那么第23个字符就是& ;.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。