Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

Gespeicherte Prozedur – Übergeben eines Parameters als XML und Lesen der Daten

Sie brauchen nur ein WHERE Klausel denke ich.

   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  

Oder Sie können es stattdessen im XPath tun, was meiner Meinung nach effizienter sein könnte

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