在SQL Server中使用OpenXML

时间:2017-10-11 06:34:51

标签: sql sql-server xml openxml

我有一张表格,其中由于某种原因,行是XML格式的。

我必须解析这些行,并从XML本身创建一个新表。

我阅读并发现SQL Server中有OpenXML。我正在使用SQL Server 2016 SP1版本。

我按照上述链接中有关如何使用XML的说明进行操作,但是:

DECLARE @idoc int, @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>';

为此,我得到:

  

Msg 137,Level 15,State 1,Line 1870,
   必须声明标量变量&#34; @ doc&#34;。

这很奇怪,因为我在上面的命令中成功声明了它。

现在:

EXEC sp_xml_preparedocument @idoc OUTPUT, @doc;
  

Msg 137,Level 15,State 2,Line 1887
   必须声明标量变量&#34; @ idoc&#34;。

这种错误可以解决吗?

1 个答案:

答案 0 :(得分:0)

您是否单独运行每个部分?

将整个事物作为一个脚本运行:

DECLARE @idoc int, @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>';
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc;
GO