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

Como passar XML de C# para um procedimento armazenado no SQL Server 2008?


Para a parte 2 da sua pergunta, veja minha resposta para Procedimento armazenado:passe XML como argumento e INSERT (pares de chave/valor) para obter um exemplo de como usar XML em um procedimento armazenado.

EDITAR :O código de exemplo abaixo é baseado no exemplo específico fornecido nos comentários.
declare @MyXML xml

set @MyXML = '<booksdetail> 
                  <isbn_13>700001048</isbn_13> 
                  <isbn_10>01048B</isbn_10> 
                  <Image_URL>http://www.landt.com/Books/large/00/70100048.jpg</Image_URL> 
                  <title>QUICK AND FLUPKE</title> 
                  <Description> PRANKS AND JOKES QUICK AND FLUPKE - CATASTROPHE QUICK AND FLUPKE </Description> 
              </booksdetail>'

select Book.detail.value('(isbn_13/text())[1]','varchar(100)') as isbn_13, 
       Book.detail.value('(isbn_10/text())[1]','varchar(100)') as isbn_10, 
       Book.detail.value('(Image_URL/text())[1]','varchar(100)') as Image_URL, 
       Book.detail.value('(title/text())[1]','varchar(100)') as title, 
       Book.detail.value('(Description/text())[1]','varchar(100)') as Description
    from @MyXML.nodes('/booksdetail') as Book(detail)