Warum wird SQL OpenXML in SQL Azure nicht unterstützt? und welche Alternativen können wir mit SQL Azure verwenden? und schließlich, wird SQL OpenXML in kommenden SQL-Versionen veraltet sein?
Antworten
Zu viele Anzeigen?Zwei Alternativen sind:
1) Die Funktionen Nodes() und Value()
Véase Beschränkungen von Stored Procedures in SQL Azure y Value(), Nodes(), und OpenXML() .
2) XQuery
Véase Einführung in XQuery in SQL Server 2005 y SQL Server 2005 XQuery und XML-DML - Teil 1 .
Das muss sich irgendwann einmal geändert haben. Es scheint, dass openxml seit dem 25.9.2017 in SQL Azure gut funktioniert. Ich habe gerade das folgende Beispiel aus https://learn.microsoft.com/en-us/sql/relational-databases/xml/examples-using-openxml auf einer SQL Azure-DB und es wurde das angezeigte Ergebnis erzielt:
DECLARE @DocHandle int
DECLARE @XmlDocument nvarchar(1000)
SET @XmlDocument = N'<ROOT>
<Customer CustomerID="VINET" ContactName="Paul Henriot">
<Order OrderID="10248" CustomerID="VINET" EmployeeID="5"
OrderDate="1996-07-04T00:00:00">
<OrderDetail ProductID="11" Quantity="12"/>
<OrderDetail ProductID="42" Quantity="10"/>
</Order>
</Customer>
<Customer CustomerID="LILAS" ContactName="Carlos Gonzlez">
<Order OrderID="10283" CustomerID="LILAS" EmployeeID="3"
OrderDate="1996-08-16T00:00:00">
<OrderDetail ProductID="72" Quantity="3"/>
</Order>
</Customer>
</ROOT>'
-- Create an internal representation of the XML document.
EXEC sp_xml_preparedocument @DocHandle OUTPUT, @XmlDocument
-- Execute a SELECT statement using OPENXML rowset provider.
SELECT *
FROM OPENXML (@DocHandle, '/ROOT/Customer',1)
WITH (CustomerID varchar(10),
ContactName varchar(20))
EXEC sp_xml_removedocument @DocHandle
Ausgabe:
CustomerID ContactName
VINET Paul Henriot
LILAS Carlos Gonzlez
Ich sehe hier kein OPENXML: https://learn.microsoft.com/en-us/azure/sql-database/sql-database-transact-sql-information#transact-sql-syntax-not-supported-in-sql-database