이 글에서는 주로 동적 쿼리를 실행하기 위한 비동적 SQL Server SQL 문에 대해 설명합니다. 실제 작업에서는 결과 집합을 제한하기 위해저장 프로시저에서 쉼표로 구분된 일련의 값을 전달하려고 했습니다. 그런데 IN 절에variable을 사용할 때마다오류 메시지
가 발생합니다. 이 글에서는 주로 동적 쿼리를 실행하기 위한 비동적 SQL ServerSQL 문에 대해 설명합니다. 실제 작업에서는 저장 프로시저를 사용해 보았습니다. 결과 세트를 제한하기 위해 쉼표로 구분된 일련의 값을 전달합니다. 하지만 IN 절에서 변수를 사용할 때마다 오류 메시지가 나타납니다.
동적 SQL 문을 실행하지 않고 쿼리를 완료할 수 있는 방법이 있나요?
결과 집합을 제한하기 위해 저장 프로시저에 쉼표로 구분된 일련의 값을 전달해 보았습니다. 하지만 IN 절에서 변수를 사용할 때마다 오류 메시지가 나타납니다. 동적 SQL ServerSQL 문을 실행하지 않고 쿼리를 완료하는 방법이 있습니까?
전문가 답변:
동적 SQL ServerSQL 문을 실행하지 않고 쿼리를 완료하는 방법이 있지만 먼저 이 질문을 살펴보겠습니다. 다음 예에서는 AdventureWorks 데이터베이스를 사용하겠습니다.
값이 하나만 있으면 실행에 문제가 없습니다.
Declare @ManagerIDs Varchar(100) Set @ManagerIDs = '3' Select * from HumanResources.Employee Where ManagerID IN (@ManagerIDs)
하지만 쉼표를 추가하면 결과는 다음과 같습니다.
Declare @ManagerIDs Varchar(100) Set @ManagerIDs = '3,6' Select * from HumanResources.Employee Where ManagerID IN (@ManagerIDs) Msg 245, Level 16, State 1, Line 4 Conversion failed when converting the varchar value '3,6' to data type int.
이것은 SQL Sever가 ManagerID 열이 정수임을 인식하여 자동으로 @ManagerID를 변수로 변환하기 때문입니다.
이 문제를 해결하려면 동적 SQL을 사용하여 이 문을 실행할 수 있습니다. 이렇게 하면 쿼리를 실행하기 전에 전체 쿼리를 동적으로 작성할 수 있습니다.
Declare @ManagerIDs Varchar(100) Set @ManagerIDs = '3,6' Declare @SQL Varchar(1000) Set @SQL = 'Select * from HumanResources.Employee Where ManagerID IN (' + @ManagerIDs + ')' EXEC (@SQL)
이렇게 하면 쿼리를 실행할 수 있지만 동적 SQL은 위험하고 일부 특정 조직에서는 허용되지도 않습니다.
그렇다면 동적 SQL을 사용하지 않고 어떻게 쿼리를 실행할 수 있을까요? 이는 XML을 통해 달성할 수 있습니다.
첫 번째 단계에서는 쉼표로 구분된문자열에서 XML 필드를 생성해야 합니다.
Declare @ManagerIDs Varchar(100) Set @ManagerIDs = '3,6' DECLARE @XmlStr XML SET @XmlStr = --Start Tag '' + --Replace all commas with an ending tag and start a new tag REPLACE( @ManagerIDs, ',', '') + --End Tag ''
다음으로 XML 값을 선택하면 결과는 다음과 같습니다.
Select @XmlStr
이제 XML 필드가 있으므로 이를 쿼리할 수 있으며 결과는 행별로 다음과 같습니다.
SELECT x.ManagerID.value('.', 'INT') AS A FROM @XmlStr.nodes('//ManagerID') x(ManagerID)
이제 활용할 수 있습니다. 이전 쿼리를 사용하여 결과를 제한할 수도 있습니다.
SELECT * FROM HumanResources.Employee WHERE ManagerID IN( SELECT x.ManagerID.value('.', 'INT') AS A FROM @XmlStr.nodes('//ManagerID') x(ManagerID) )
또는 Inner Join을 사용하여 결과를 제한할 수도 있습니다.
SELECT * FROM HumanResources.Employee AS A INNER JOIN (SELECT x.ManagerID.value('.', 'INT') AS ManagerID FROM @XmlStr.nodes('//ManagerID') x(ManagerID)) B ON A.ManagerID = B.ManagerID
위 관련 내용은 동적 쿼리를 실행하기 위한 비동적 SQL Server SQL 문에 대한 설명입니다. 이와 관련하여 도움을 주세요.
위 내용은 비동적 SQL Server SQL 문을 사용하여 동적 쿼리를 실행하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!