【问题标题】:Get specific XML Child node in SQL Server在 SQL Server 中获取特定的 XML 子节点
【发布时间】:2023-03-22 21:05:01
【问题描述】:

我正在尝试使用 MS SQL Server 中的逻辑键将 XMl 加载到不同的表中。 当我在 SQL 中获取所有子节点时,我被卡住了。

<Books>
<Book>
    <Name>Book1</Name>
    <Author>abc</Author>
    <Stores>
        <Name>Amazon</Name>
    </Stores>
</Book>
<Book>
    <Name>Book2</Name>
    <Author>cde</Author>
    <Stores>
        <Name>Flipkart</Name>
    </Stores>
</Book>
</Books>

我想得到如下结果。

BookId  Name   Author  StoreXML
1       Book1  abc     <Stores><Name>Amazon</Name></Stores>  
2       Book2  cde     <Stores><Name>Flipkart</Name></Stores>

【问题讨论】:

    标签: sql sql-server xml sqlxml


    【解决方案1】:

    这样试试

    DECLARE @xml XML=
    N'<Books>
    <Book>
        <Name>Book1</Name>
        <Author>abc</Author>
        <Stores>
            <Name>Amazon</Name>
        </Stores>
    </Book>
    <Book>
        <Name>Book2</Name>
        <Author>cde</Author>
        <Stores>
            <Name>Flipkart</Name>
        </Stores>
    </Book>
    </Books>';
    
    SELECT ROW_NUMBER() OVER(ORDER BY(SELECT NULL)) AS BookId --there is no id in your XML...
          ,b.value('(Name/text())[1]','nvarchar(max)') AS BookName 
          ,b.value('(Author/text())[1]','nvarchar(max)') AS Author
          ,b.query('Stores') AS StoreXML 
    FROM @xml.nodes('/Books/Book') AS A(b)
    

    【讨论】:

    • 谢谢,我使用 @xml.query 而不是 b.query 来获取特定的子节点。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2023-03-09
    • 2012-09-23
    • 1970-01-01
    • 2021-09-14
    相关资源
    最近更新 更多