Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

Stored procedure - Passando um parâmetro como xml e lendo os dados


Você só precisa de um WHERE cláusula eu acho.
   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  

Ou você pode fazer isso no XPath, o que acho que pode ser mais eficiente
   FROM OPENXML (@currRecord, 'ios/io[C1 and C2 and C3]', 1)