tsql:解析XML以生成插入语句

时间:2010-11-02 21:38:11

标签: xml sql-server-2005 tsql

基本上我想将一个xml块作为参数发送到我的ms sql 2005 db,它会被解析并插入行数据。

我见过很多关于在数据库中存储xml,或者将表数据作为xml检索的例子,但是没有使用xml来插入表格数据的例子。

我在c#中有一个方法,它在循环中调用我的存储过程来插入数据,但我希望我可以将数据格式化为xml并将其全部插入到一个调用中。

2 个答案:

答案 0 :(得分:1)

看一下这个例子:

DECLARE @idoc int
DECLARE @doc varchar(1000)
SET @doc ='
<ROOT>
<Customer CustomerID="VINET" ContactName="Paul Henriot">
   <Order CustomerID="VINET" EmployeeID="5" OrderDate="1996-07-04T00:00:00">
      <OrderDetail OrderID="10248" ProductID="11" Quantity="12"/>
      <OrderDetail OrderID="10248" ProductID="42" Quantity="10"/>
   </Order>
</Customer>
<Customer CustomerID="LILAS" ContactName="Carlos Gonzlez">
   <Order CustomerID="LILAS" EmployeeID="3" OrderDate="1996-08-16T00:00:00">
      <OrderDetail OrderID="10283" ProductID="72" Quantity="3"/>
   </Order>
</Customer>
</ROOT>'
--Create an internal representation of the XML document.
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc
-- Execute a SELECT statement that uses the OPENXML rowset provider.
SELECT    *
FROM       OPENXML (@idoc, '/ROOT/Customer',1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20))

这样可以获得结果:

CustomerID ContactName          
---------- -------------------- 
VINET      Paul Henriot
LILAS      Carlos Gonzlez

如果您提供XML,我可以提供更多信息。

从这里无耻地偷走了:

http://msdn.microsoft.com/en-us/library/aa276847%28SQL.80%29.aspx

答案 1 :(得分:0)

我经常这样做。从SQL Server 2005开始,提供了本地XML data type,以及用于查询的methods(通过XQuery)。 ADO.NET aslo添加了对SqlDbType.Xml枚举和SqlXml类的支持。有关几个示例,请参阅文章"XML Data Type Support in ADO.NET 2.0: Handling XML from SQL Server 2005"