SQL Server에서 "스칼라 변수를 선언해야 합니다" 오류 문제 해결
전체 입력 매개변수(@RowFrom 및 @RowTo)를 사용할 때 저장 프로시저를 실행하고 T-SQL을 사용하여 SQL 쿼리를 컴파일할 때 매개 변수를 다음과 같이 선언하지 않고 사용하면 오류가 발생할 수 있습니다. 쿼리 내부에 스칼라 변수가 있습니다.
이 문제를 해결하려면 변수를 사용하기 전에 선언하는 것이 중요합니다. 그러나 정수 매개 변수(@RowTo)를 문자열과 연결하여 새 변수에 할당하려는 시도는 올바르지 않습니다. 대신 CONVERT() 함수를 사용하여 정수 값을 문자열로 변환하여 연결합니다.
예를 들어 다음 대신 다음을 사용합니다.
SET @sql = N'DECLARE @Rt int; SET @Rt = ' + @RowTo;
사용:
SET @sql = N'DECLARE @Rt int; SET @Rt = ' + CONVERT(VARCHAR(12), @RowTo);
이렇게 하면 매개변수가 실행될 때 문자열로 처리되어 "스칼라 변수를 선언해야 합니다"를 방지할 수 있습니다. 오류가 발생했습니다.
또한 연결 대신 적절한 매개 변수화를 사용하여 쿼리에 매개 변수 값을 삽입하는 것이 좋습니다. 이 방법은 SQL 삽입 공격을 방지하여 보안을 강화합니다. 쿼리를 매개 변수화하려면 다음 줄을 추가하세요.
EXEC sys.sp_executesql @sql, N'@RowFrom int, @RowTo int', @RowFrom, @RowTo;
이러한 권장 사항을 따르면 "스칼라 변수를 선언해야 합니다." 오류를 해결하고 저장 프로시저 내에서 SQL 쿼리를 정확하게 실행할 수 있습니다.
위 내용은 SQL Server 저장 프로시저에서 '스칼라 변수를 선언해야 합니다' 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!