我有下一个XML
文件:
<?xml version="1.0" encoding="utf-8"?>
<DynamicEntity Name="ProductsMilk">
<Field Name="Name" Type="nvarchar(256)" AllowNulls="false" />
<Field Name="Description" Type="ntext" AllowNulls="false" />
<Field Name="Price" Type="float" AllowNulls="false" />
</DynamicEntity>
我需要从XML-node
的任何选项中读取一些值,例如我需要使用T-SQL
从字段节点读取类型选项的值。
如何使用MSSQL
中的内部 OpenXML 提供程序执行此操作?
答案 0 :(得分:2)
以下内容将从您的XML中提取所有数据:
DECLARE @doc VARCHAR(1000) = '<?xml version="1.0" encoding="utf-8"?>
<DynamicEntity Name="ProductsMilk">
<Field Name="Name" Type="nvarchar(256)" AllowNulls="false" />
<Field Name="Description" Type="ntext" AllowNulls="false" />
<Field Name="Price" Type="float" AllowNulls="false" />
</DynamicEntity>';
DECLARE @iDoc INT;
EXECUTE sp_xml_preparedocument @idoc OUTPUT, @doc;
SELECT *
FROM OPENXML(@iDoc, 'DynamicEntity/Field')
WITH
( DynamicEntityName VARCHAR(100) '../@Name',
FieldName VARCHAR(100) '@Name',
[Type] VARCHAR(100) '@Type',
AllowNulls VARCHAR(100) '@AllowNulls'
);
基本上,您只需要为xml属性指定列映射。
答案 1 :(得分:1)
这是一个解决方案:
DECLARE @x XML = '<?xml version="1.0" encoding="utf-8"?>
<DynamicEntity Name="ProductsMilk">
<Field Name="Name" Type="nvarchar(256)" AllowNulls="false" />
<Field Name="Description" Type="ntext" AllowNulls="false" />
<Field Name="Price" Type="float" AllowNulls="false" />
</DynamicEntity>'
SELECT t.c.value(N'../@Name', N'nvarchar(100)'),
t.c.value(N'@Name', N'nvarchar(100)'),
t.c.value(N'@Type', N'nvarchar(100)'),
t.c.value(N'@AllowNulls', N'nvarchar(100)')
FROM @x.nodes(N'/DynamicEntity/Field') t(c)