使用xml格式

时间:2017-12-04 22:36:59

标签: sql-server xml sql-server-2008-r2 for-xml-path

如何将表格中已经是XML格式的列的值创建为XML中属性的值并保留其XML格式(括号,引号等)? (似乎正在发生的事情的术语是字符(<,>,")正在被授权。)(SQL SERVER 2008 R2)

declare @T table (
ID int identity,
Col1 varchar(200),
Col2 varchar(max)
);

insert @T
select 'ABC', 'Value01'
union
select 'DEF', '<Ele01>A01</Ele01>'
union
select 'GHI', '<Elements><Ele02>A02</Ele02><Ele03>A03</Ele03></Elements>'
union
select 'JKL', '<Ele04 Att01="V01" Att02="V02" />';

select (
    select
        Col1 as '@Col1',
        Col2 as '@Col2'
    from @T
    for xml path(N'Item'), type
    ) as TValues
for xml path(N'T'), type, elements xsinil;

结果如下:

<T xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <TValues>
    <Item Col1="ABC" Col2="Value01" />
    <Item Col1="DEF" Col2="<Element01>A01</Element01>" />
    <Item Col1="GHI" Col2="<Elements><Element02>A02</Element02><Element03>A03</Element03></Elements>" />
    <Item Col1="JKL" Col2="<Element04 Att01="V01" Att02="V02" />" />
  </TValues>
</T>

这是实际结果:

<T xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <TValues>
    <Item Col1="ABC" Col2="Value01" />
    <Item Col1="DEF" Col2="&lt;Element01&gt;A01&lt;/Element01&gt;" />
    <Item Col1="GHI" Col2="&lt;Elements&gt;&lt;Element02&gt;A02&lt;/Element02&gt;&lt;Element03&gt;A03&lt;/Element03&gt;&lt;/Elements&gt;" />
    <Item Col1="JKL" Col2="&lt;Element04 Att01=&quot;V01&quot; Att02=&quot;V02&quot; /&gt;" />
  </TValues>
</T>

我已经搜索了一个答案,这些是我能找到的唯一可以解决这个问题的链接: http://blogs.lobsterpot.com.au/2010/04/15/handling-special-characters-with-for-xml-path/ How do I avoid character encoding when using "FOR XML PATH"? https://www.red-gate.com/simple-talk/sql/learn-sql-server/using-the-for-xml-clause-to-return-query-results-as-xml/

我知道我可以在事后取代有权使用的角色,但我相信必须有更好的方法。 我非常感谢知道如何实现这一目标的人的帮助。

如果我的问题未达到某人的标准,我道歉。

2 个答案:

答案 0 :(得分:1)

您的“应该看起来像”XML根本不是XML - 这就是您的工具无法帮助您的原因。没有一致的XML处理器可以帮助您生成格式不正确的XML。您需要修复XML设计,以便标记不会出现在属性值中,或者您需要处理工具为您提供的转义版本。

如果您说无法修复XML设计或处理属性值中的转义字符,那么您必须在没有XML库和工具支持的情况下生存,因为它们不会帮助您“应该看起来像“格式。准备在字符流级​​别操作,并构建自己的工具集。同时为数据的使用者准备他们也无法使用XML工具。

底线:不要生成格式不正确的XML。

答案 1 :(得分:0)

正如您所知,您的XML无效。生成字符串很容易,看起来像XML ,但这并不意味着您的字符串是有效的XML

  

我知道我可以在

之后替换有权使用的字符

如果你这样做,你必须在REPLACE的字符串级别上执行此操作,但这会破坏您的XML。没有有效的工具可以阅读这个!

第一个问题是:为什么要将此XML存储在VARCHAR(MAX)列中? XML不只是一些带有花哨附加功能的愚蠢的文本...... 你应该使这个列XML类型。这将确保您的片段是有效的XML。

您可能会做什么:您可以将片段作为有效的子元素放入XML中:

select (
    select
        Col1 as '@Col1',
        CAST(Col2 AS XML) as 'Col2'
    from @T
    for xml path(N'Item'), type
    ) as TValues
for xml path(N'T'), type, elements xsinil;

结果

<T xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
  <TValues>
    <Item Col1="ABC">
      <Col2>Value01</Col2>
    </Item>
    <Item Col1="DEF">
      <Col2>
        <Ele01>A01</Ele01>
      </Col2>
    </Item>
    <Item Col1="GHI">
      <Col2>
        <Elements>
          <Ele02>A02</Ele02>
          <Ele03>A03</Ele03>
        </Elements>
      </Col2>
    </Item>
    <Item Col1="JKL">
      <Col2>
        <Ele04 Att01="V01" Att02="V02" />
      </Col2>
    </Item>
  </TValues>
</T>