首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >XML explicit group by parent标记无效

XML explicit group by parent标记无效
EN

Stack Overflow用户
提问于 2015-03-02 18:52:26
回答 1查看 155关注 0票数 1

我要求输出如下所示。但是当我执行我的代码时,我没有将产品正确地分组到每个父级下(它应该像在“美国”国家代码下我们需要有三个产品,在"FR“下我们需要有两个产品)。

代码语言:javascript
运行
复制
<?xml version="1.0" encoding="utf-8"?>
<ComProducts>
  <Country Code="US">
    <Product>
      <manufacturername>abc</manufacturername>
      <productname>xyz road</productname>
      <upc>RJ</upc>
    </Product>
    <Product>
      <manufacturername>temp</manufacturername>
      <productname>ppp road</productname>
      <upc>RJ</upc>
    </Product>
    <Product>
      <manufacturername>ccc</manufacturername>
      <productname>oli Com</productname>
      <upc>CL</upc>
    </Product>
  </Country>
  <Country Code="FR">
    <Product>
      <manufacturername>xxx</manufacturername>
      <productname>aaa road</productname>
      <upc>NY</upc>
    </Product>
    <Product>
      <manufacturername>eee</manufacturername>
      <productname>olkiu road</productname>
      <upc>CL</upc>
    </Product>
  </Country>
</ComProducts>

代码:

代码语言:javascript
运行
复制
DECLARE @Products TABLE   
        (   
           code             VARCHAR(10),   
           manufacturername VARCHAR(50),   
           productname      NVARCHAR(255),   
           upc              VARCHAR(100)  

        )   

      INSERT INTO @Products   
            select  'en-us', 'abc', 'xyz road', 'RJ' union all
            select  'en-us', 'temp', 'ppp road', 'RJ' union all
            select  'fr-fr', 'xxx', 'aaa road', 'NY' union all
            select  'en-us', 'ccc', 'oli Com', 'CL' union all
            select  'fr-fr', 'eee', 'olkiu road', 'CL' 


      SELECT 1    AS Tag,   
             NULL AS Parent,   
             NULL AS 'ComProducts!1!',   
             NULL AS 'Country!2!locale',
             NULL AS 'Products!3!',   
             NULL AS 'Products!3!manufacturerName!Element',   
             NULL AS 'Products!3!productName!cdata',   
             NULL AS 'Products!3!upc!Element'
      UNION ALL   
      SELECT 2 AS Tag,   
             1 AS Parent,   
             NULL,   
             code,
             NULL,   
             manufacturername,   
             productname,   
             upc
             FROM   @Products  
      UNION ALL   
      SELECT 3 AS Tag,   
             2 AS Parent,   
             NULL,   
             NULL,
             NULL,   
             manufacturername,   
             productname,   
             upc  

      FROM   @Products 
      FOR    xml explicit
EN

回答 1

Stack Overflow用户

发布于 2016-01-25 17:19:25

我建议您使用for xml path而不是for xml explicit来完成此任务。

代码语言:javascript
运行
复制
select P1.code as '@Code',
       (
       select P2.manufacturername,
              P2.productname,
              P2.upc
       from @Products as P2
       where P1.code = P2.code
       for xml path('Product'), type
       )
from @Products as P1
group by P1.code
for xml path('Country'), root('ComProducts');

结果:

代码语言:javascript
运行
复制
<ComProducts>
  <Country Code="en-us">
    <Product>
      <manufacturername>abc</manufacturername>
      <productname>xyz road</productname>
      <upc>RJ</upc>
    </Product>
    <Product>
      <manufacturername>temp</manufacturername>
      <productname>ppp road</productname>
      <upc>RJ</upc>
    </Product>
    <Product>
      <manufacturername>ccc</manufacturername>
      <productname>oli Com</productname>
      <upc>CL</upc>
    </Product>
  </Country>
  <Country Code="fr-fr">
    <Product>
      <manufacturername>xxx</manufacturername>
      <productname>aaa road</productname>
      <upc>NY</upc>
    </Product>
    <Product>
      <manufacturername>eee</manufacturername>
      <productname>olkiu road</productname>
      <upc>CL</upc>
    </Product>
  </Country>
</ComProducts>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28807977

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档