sql >> Databasteknik >  >> RDS >> Sqlserver

Lagrad procedur:skicka XML som ett argument och INSERT (nyckel/värdepar)

Här är ett exempel:

/* Create the stored procedure */
create procedure ParseXML (@InputXML xml)
as
begin
    declare @MyTable table (
        id int,
        value int
    )

    insert into @MyTable 
        (id, value)
        select Row.id.value('@id','int'), Row.id.value('@value','int') 
            from @InputXML.nodes('/Rows/Row') as Row(id)        

    select id, value
        from @MyTable
end
go

/* Create the XML Parameter */
declare @XMLParam xml
set @XMLParam = '<Rows>
                     <Row id="1" value="100" />
                     <Row id="2" value="200" />
                     <Row id="3" value="300" />
                 </Rows>'

/* Call the stored procedure with the XML Parameter */
exec ParseXML @InputXML = @XMLParam

/* Clean up - Drop the procedure */
drop procedure ParseXML
go


  1. GROUP BY-sats med alias?

  2. Hitta icke-ASCII-tecken i varchar-kolumner med SQL Server

  3. Dynamisk SQL - EXEC(@SQL) kontra EXEC SP_EXECUTESQL(@SQL)

  4. Konvertera avgränsad sträng till flera värden i mysql