0

这是关于 SQL 中的 XQuerying 的问题(SQL Server 2008)

最初,我有一个需要以不同方式输出的 XML,以供参考:

declare @XMLNODE table (id int identity, doc xml)
insert @XMLNODE (doc) values (   
'
 <Root>
    <Elements>
      <Items>
        <OldItem>

          <ID>1</ID>
          <Show Pointer="yes" />
          <Display Pointer="Display">
            <Detail1>some Details</Detail1>
          </DisplayDetails>

        </OldItem>
      </Items>
    </Elements>
    </Root>'
)

    SELECT  a.value('(ID)[1]','int') as ID,
    a.value('(Show/@Pointer)[1]', 'varchar(5)') AS ShowItem,
    a.value('Display[1]/@Pointer[1]="Display"', 'varchar(10)') as DisplayDetails, -- Set to 'true' or 'false'
    a.value('DisplayDetails[1][@Pointer[1]="Display"]/Detail1[1]', 'varchar(max)') as Detail1
    FROM    @XMLNODE t
    cross apply
    t.doc.nodes('//OldItem') x(a)
    FOR XML PATH ('Items'),
    ROOT('Elements')

所以,现在我有一个这样的 XML:

<Elements>
  <Items>
    <ID>1</ID>
    <ShowItem>yes</ShowItem>
    <DisplayDetails>true</DisplayDetails>
    <Detail1>some Details</Detail1>
  </Items>
</Elements>

想要根据它是否为真/是等添加一些修改为 1 或无值。

即期望:

<Elements>
  <Items>
    <ID>1</ID>
    <ShowItem>1</ShowItem>
    <DisplayDetails>1</DisplayDetails>
    <Detail1>some Details</Detail1>
  </Items>
</Elements>

另外,如果<DisplayDetails>false</DisplayDetails>我只想将其更新为<DisplayDetails />.

有没有办法直接比较查询中的输入(例如,是或否)并将其设置为 1 或 0 而不是真或假?我正在使用 .query 来使用这些值并根据需要添加其他信息..

4

1 回答 1

0

我很少从 SQL 查询 XML,但是如果我对任何不是 XML 的东西执行此操作,我会在 SELECT 语句中执行类似的操作:

SELECT  a.value('(ID)[1]','int') as ID,
case 
  when a.value('(Show/@Pointer)[1]', 'varchar(5)') = 'yes' then '1'
  else '0'
End case as 'ShowItem',
a.value('Display[1]/@Pointer[1]="Display"', 'varchar(10)') as DisplayDetails, -- Set to 'true' or 'false'
a.value('DisplayDetails[1][@Pointer[1]="Display"]/Detail1[1]', 'varchar(max)') as Detail1
FROM    @XMLNODE t
cross apply
t.doc.nodes('//OldItem') x(a)

注意:这还没有尝试过,我不在数据库客户端上以确保我的语法完全正确。但是,检查数据库中的值并根据该值显示其他内容是相对简单的。

于 2011-04-20T16:25:39.370 回答