TSQL - использовать переменные в OPENXML - PullRequest
1 голос
/ 08 августа 2011

Предположим, у меня есть такой запрос -

SELECT * FROM 
    OPENXML(@i, '/root/authors', 2) 
        WITH authors

Теперь я хочу передать '/root' через такой параметр / переменную, как -

DECLARE @nodeName varchar(MAX) ----> EDIT: Solution- Use fixed length instead of MAX
SET @nodeName = '/root'

и вместо этого используйте @nodeName. Затем объединить остальные элементы динамически. Я получаю сообщение об ошибке только при использовании @nodeName в параметре OPENXML.

Ответы [ 2 ]

2 голосов
/ 08 августа 2011

Лучше использовать новый тип XML.

create proc [dbo].[getLocationTypes](@locationIds XML,
@typeIds XML=null)
as  
begin  
set nocount on  


SELECT locationId, typeId
FROM xrefLocationTypes 
WHERE locationId 
IN (SELECT Item.value('.', 'int' )
FROM @locationIDs.nodes('IDList/ID') AS x(Item))
AND (typeId IN
 (SELECT Item.value('.', 'int' )
FROM @typeIds.nodes('IDList/ID') AS x(Item)))
ORDER BY 1, 2

end  

И тогда вы бы назвали это как:

EXECUTE dbo.getLocationTypes '<IDList><ID>1</ID><ID>3</ID></IDList>', 
'<IDList><ID>200</ID><ID>300</ID><ID>400</ID></IDList>'    
1 голос
/ 08 августа 2011

Я попробовал следующее в SQL 2008 R2, и оно отлично работает.

DECLARE @idoc int
DECLARE @doc varchar(1000)
SET @doc ='
<ROOT>
<Customer CustomerID="VINET" ContactName="Paul Henriot">
   <Order CustomerID="VINET" EmployeeID="5" OrderDate="1996-07-04T00:00:00">
      <OrderDetail OrderID="10248" ProductID="11" Quantity="12"/>
      <OrderDetail OrderID="10248" ProductID="42" Quantity="10"/>
   </Order>
</Customer>
<Customer CustomerID="LILAS" ContactName="Carlos Gonzlez">
   <Order CustomerID="LILAS" EmployeeID="3" OrderDate="1996-08-16T00:00:00">
      <OrderDetail OrderID="10283" ProductID="72" Quantity="3"/>
   </Order>
</Customer>
</ROOT>'
--Create an internal representation of the XML document.
EXEC sp_xml_preparedocument @idoc OUTPUT, @doc
-- Execute a SELECT statement that uses the OPENXML rowset provider.
DECLARE @NodeName VARCHAR(100)
SET @NodeName = '/ROOT/Customer'
SELECT    *
FROM       OPENXML (@idoc, @NodeName,1)
            WITH (CustomerID  varchar(10),
                  ContactName varchar(20))

Возможно, что другие версии SQL поддерживают только использование NVARCHAR в качестве параметра, а не VARCHAR.

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...