Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

XML jako parametr w procedurze składowanej (serwer sql)

Twoje pierwsze zapytanie, które twierdzisz, że działa, w rzeczywistości nie działa z podanym kodem XML. Tak powinno być.

declare @handle int
declare @XML xml = '<ROOT><ids><id>2013-01-01</id></ids><ids><id>2013-01-02</id></ids></ROOT>'
exec sp_xml_preparedocument @handle out, @XML
select * from openxml(@handle, '/ROOT/ids', 2) with (id Date)
exec sp_xml_removedocument @handle

Druga wersja powinna być

declare @handle int
declare @XML xml = '<ROOT><id>2013-01-01</id><id>2013-01-02</id></ROOT>'
exec sp_xml_preparedocument @handle out, @XML
select * from openxml(@handle, '/ROOT/id', 2) with (id Date '.')
exec sp_xml_removedocument @handle

Ponieważ używasz SQL Server 2008 lub nowszego, możesz zamiast tego użyć typu danych XML.

declare @XML xml = '<ROOT><id>2013-01-01</id><id>2013-01-02</id></ROOT>'

select T.N.value('text()[1]', 'date') as id
from @XML.nodes('ROOT/id') as T(N)



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Zwróć nazwę lokalnego serwera w SQL Server z @@NAZWASERWERA

  2. Jaki jest najlepszy sposób przechowywania danych historycznych w SQL Server 2005/2008?

  3. SQL Server - gdzie jest sys.functions?

  4. Czy instrukcja WITH jest wykonywana raz na zapytanie, czy raz na wiersz?

  5. Tworzenie planów konserwacji w SQL Server