繁体   English   中英

如何从T-SQL获取自定义XML?

[英]How to get custom XML from T-SQL?

我有这个查询:

select f.n, t.l, grp.n, cat.n, col.n, col_value
        from fc 
            inner join f on f.idfc = fc.idfc
            inner join t on t.idf = f.idf
            inner join grp on grp.idt = t.idt
            inner join cat on cat.idgrp = grp.idgrp
            inner join col on col.idcat = cat.idcat
            inner join col_value on col_value.idcol = col.idcol
    for xml auto, root('fc')
    ;

它返回以下xml:

<fc>
  <f n="341.11.7">
    <t l="A">
      <grp n="ID">
        <cat n="10">
          <col n="R">
            <col_value col_value="341" />
          </col>
          <col n="S">
            <col_value col_value="11" />
          </col>
          <col n="H">
            <col_value col_value="7" />
          </col>
        </cat>
      </grp>
    </t>
  </f>
</fc>

但我需要col_value元素必须如下所示:

<col_value>341</col_value>

因此,如何修改查询以达到以下结果?

<fc>
  <f n="341.11.7">
    <t l="A">
      <grp n="ID">
        <cat n="10">
          <col n="R">
            <col_value>341</col_value>
          </col>
          <col n="S">
            <col_value>11</col_value>
          </col>
          <col n="H">
            <col_value>7</col_value>
          </col>
        </cat>
      </grp>
    </t>
  </f>
</fc>

谢谢大家。 查尔斯。

尝试像这样更改查询:

select f.n, t.l, grp.n, cat.n, col.n, (select col_value for xml path,type).query('/row/col_value') )
    from fc 
        inner join f on f.idfc = fc.idfc
        inner join t on t.idf = f.idf
        inner join grp on grp.idt = t.idt
        inner join cat on cat.idgrp = grp.idgrp
        inner join col on col.idcat = cat.idcat
        inner join col_value on col_value.idcol = col.idcol
for xml auto, root('fc')
;

我希望这有帮助。

select
    f.n, t.l, grp.n, cat.n, col.n,
    (select col_value for xml path(''), type)
from fc 
    inner join f on f.idfc = fc.idfc
    inner join t on t.idf = f.idf
    inner join grp on grp.idt = t.idt
    inner join cat on cat.idgrp = grp.idgrp
    inner join col on col.idcat = cat.idcat
    inner join col_value on col_value.idcol = col.idcol
for xml auto, root('fc')

sql小提琴演示

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM