Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

XML-Leistung des SQL-Prozesses:In Spalten einer Tabelle einfügen

Das erste, was ich versuchen würde, ist die Angabe des text() -Knoten, wenn Sie den XML-Datentyp verwenden, um zu verhindern, dass SQL Server eine Tiefensuche nach Textelementen durchführt.

INSERT INTO SUPPLIER
   (IDCONO
   ,IDSUNO
   ,IDSUTY)
SELECT
   T.C.value('(IDCONO/text())[1]', 'VARCHAR(50)') as IDCONO,
   T.C.value('(IDSUNO/text())[1]', 'VARCHAR(50)') as IDSUNO,
   T.C.value('(IDSUTY/text())[1]', 'VARCHAR(50)') as IDSUTY
FROM @data.nodes('/Suppliers/Supplier') T(C)

Wenn das nicht gut genug ist, würde ich es stattdessen mit OPENXML versuchen.

DECLARE @idoc INT
EXEC sp_xml_preparedocument @idoc OUT, @data

INSERT INTO SUPPLIER
   (IDCONO
   ,IDSUNO
   ,IDSUTY)
SELECT IDCONO, IDSUNO, IDSUTY
FROM OPENXML(@idoc, '/Suppliers/Supplier', 2) WITH
        (IDCONO VARCHAR(50),
         IDSUNO VARCHAR(50),
         IDSUTY VARCHAR(50))


EXEC sp_xml_removedocument @idoc