在 SQL 服务器中使用 OpenXML
Using OpenXML in SQL Server
我有一个 table,出于某种原因,其中的行采用 XML 格式。
我必须解析这些行,并从 XML 本身创建一个新的 table。
我阅读并发现 SQL 服务器中有 OpenXML。我正在使用 SQL Server 2016 SP1 版本。
我按照上面 link 中关于如何使用 XML 的说明进行操作,但是:
DECLARE @idoc int, @doc varchar(1000);
Command(s) completed successfully.
下一个命令:
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
Must declare the scalar variable "@doc".
这很奇怪,因为我只是在上面的命令中成功声明了它。
现在:
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc;
Msg 137, Level 15, State 2, Line 1887
Must declare the scalar variable "@idoc".
有什么方法可以解决这个错误?
你 运行 每个部分都是单独的吗?
运行 整个脚本作为一个脚本:
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
我有一个 table,出于某种原因,其中的行采用 XML 格式。
我必须解析这些行,并从 XML 本身创建一个新的 table。
我阅读并发现 SQL 服务器中有 OpenXML。我正在使用 SQL Server 2016 SP1 版本。
我按照上面 link 中关于如何使用 XML 的说明进行操作,但是:
DECLARE @idoc int, @doc varchar(1000);
Command(s) completed successfully.
下一个命令:
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
Must declare the scalar variable "@doc".
这很奇怪,因为我只是在上面的命令中成功声明了它。
现在:
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc;
Msg 137, Level 15, State 2, Line 1887
Must declare the scalar variable "@idoc".
有什么方法可以解决这个错误?
你 运行 每个部分都是单独的吗?
运行 整个脚本作为一个脚本:
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