sql >> Database >  >> RDS >> Sqlserver

XML bulksgewijs importeren in SQL Server

SQL Server kan XML lezen en naar behoefte invoegen. Hier is een voorbeeld van een XML-bestand en invoeging uit hier :

XML:

<Products>
  <Product>
    <SKU>1</SKU>
    <Desc>Book</Desc>
  </Product>
  <Product>
    <SKU>2</SKU>
    <Desc>DVD</Desc>
  </Product>
  <Product>
    <SKU>3</SKU>
    <Desc>Video</Desc>
  </Product>
</Products>

Instructie invoegen die de XML ontleedt:

INSERT INTO Products (sku, product_desc) 
SELECT X.product.query('SKU').value('.', 'INT'),
       X.product.query('Desc').value('.', 'VARCHAR(30)')
FROM ( 
SELECT CAST(x AS XML)
FROM OPENROWSET(
     BULK 'C:\Products.xml',
     SINGLE_BLOB) AS T(x)
     ) AS T(x)
CROSS APPLY x.nodes('Products/Product') AS X(product);


  1. Welke indexen om de prestaties van JOIN en GROUP BY . te verbeteren

  2. Waarde invoegen en instellen met max()+1 problemen

  3. Hoe kan ik mysql gebruiken in C++?

  4. ontbrekende sleutelwoordfout in orakel CASE WHEN sql-instructie