sql >> Base de Datos >  >> RDS >> Sqlserver

Procedimiento almacenado:pasar un parámetro como xml y leer los datos

Solo necesitas un WHERE cláusula, creo.

   INSERT INTO SN_IO ( [C1] ,[C2]  ,[C3] )
   SELECT [C1] ,[C2] ,[C3]
   FROM OPENXML (@currRecord, 'ios/io', 1)
   WITH ([C1] [varchar](25)       'C1',
         [C2] [varchar](25)       'C2',
         [C3] [varchar](20)       'C3'  )    
    WHERE  [C1]  IS NOT NULL  AND [C2]  IS NOT NULL AND [C3] IS NOT NULL  

O puede hacerlo en XPath, lo que supongo que puede ser más eficiente

   FROM OPENXML (@currRecord, 'ios/io[C1 and C2 and C3]', 1)