Чтение XML в хранимой процедуре - PullRequest
0 голосов
/ 15 декабря 2011

Я хочу прочитать файл XLSX в XML, передать этот XML в хранимую процедуру, прочитать этот XML внутри SP и вставить записи из XML в таблицу. вот мой код C #

 FileStream stream = File.Open(FilePath, FileMode.Open, FileAccess.Read);
   IExcelDataReader excelReader = ExcelReaderFactory.CreateOpenXmlReader(stream);

   DataSet result = excelReader.AsDataSet();

   excelReader.IsFirstRowAsColumnNames = true;

   string xmlDS = result.GetXml();

Я передам xmlDS как строку в SP. Теперь мне нужен SP, чтобы прочитать этот файл и вставить данные в таблицу.

1 Ответ

0 голосов
/ 15 декабря 2011

вы можете использовать OPENXML, который обеспечивает представление набора строк поверх документа XML

DECLARE @idoc int
DECLARE @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>'
--Create an internal representation of the XML document.
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc
-- Execute a SELECT statement that uses the OPENXML rowset provider.
SELECT    *
FROM       OPENXML (@idoc, '/ROOT/Customer',1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20))

для получения дополнительной информации:

http://msdn.microsoft.com/en-us/library/ms186918.aspx

, затем вы можете использовать SELECTвставить ваши данные, как показано здесь

...