首页 > 解决方案 > 如何使用 SQL Server 从表中的 xml 列中提取值

问题描述

我正在尝试从 SQL Server 表中的 XML 列中提取值。我有这个InsuranceEntity带有列InsuranceEntity_ID和的表EntityXML

EntityXML列具有以下值:

<insurance insurancepartnerid="CIGNA" sequencenumber="1" 
           subscriberidnumber="1234567" groupname="Orthonet-CIGNA" 
           groupnumber="7654321" copaydollaramount="1" />

如何从该列中提取subscriberidnumber和?groupnumberEntityXML

标签: sqlxmlsql-server-2008xquery

解决方案


XQuery 方法.nodes().value()救援。

您可能需要调整数据类型。我全面使用了一个通用VARCHAR(20)的。

SQL

--DDL and sample data population, start
DECLARE @tbl TABLE (InsuranceEntity_ID INT IDENTITY PRIMARY KEY, EntityXML XML);
INSERT INTO @tbl (EntityXML) VALUES
(N'<insurance insurancepartnerid="CIGNA" sequencenumber="1"
           subscriberidnumber="1234567" groupname="Orthonet-CIGNA"
           groupnumber="7654321" copaydollaramount="1"/>');
--DDL and sample data population, end

SELECT InsuranceEntity_ID
    , c.value('@subscriberidnumber', 'VARCHAR(20)') AS subscriberidnumber
    , c.value('@groupnumber', 'VARCHAR(20)') AS groupnumber 
FROM @tbl
    CROSS APPLY EntityXML.nodes('/insurance') AS t(c);

输出

+--------------------+--------------------+-------------+
| InsuranceEntity_ID | subscriberidnumber | groupnumber |
+--------------------+--------------------+-------------+
|                  1 |            1234567 |     7654321 |
+--------------------+--------------------+-------------+

推荐阅读