Ver Mensaje Individual
  #4 (permalink)  
Antiguo 20/02/2008, 10:21
Avatar de royrojas
royrojas
 
Fecha de Ingreso: diciembre-2004
Mensajes: 458
Antigüedad: 20 años
Puntos: 3
Re: Problema con Stored Procedures

Funciona igual a un select, como si fuera una tabla a la cual le haces select e insertas en otra tabla.

Código:
SELECT    *
FROM       OPENXML (@idoc, '/ROOT/Customer',1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20)) 
WHERE CustomerID = 'LILAS' 

Código:
SELECT    CustomerID
FROM       OPENXML (@idoc, '/ROOT/Customer',1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20)) 
WHERE CustomerID = 'LILAS' 

Ahora mira el mismo ejemplo que inserte los datos en una tabla temporal.

Código:
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

CREATE TABLE #TablaTemporal (CustomerID varchar(10), ContactName varchar(20))

INSERT INTO #TablaTemporal 
SELECT *
FROM       OPENXML (@idoc, '/ROOT/Customer',1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20)) 
WHERE CustomerID = 'LILAS'

SELECT * FROM #TablaTemporal
__________________
roy rojas
Programación en Español: DotNetcr.com