> 데이터 베이스 > MySQL 튜토리얼 > SQL Server 저장 프로시저에서 '스칼라 변수를 선언해야 합니다' 오류를 해결하는 방법은 무엇입니까?

SQL Server 저장 프로시저에서 '스칼라 변수를 선언해야 합니다' 오류를 해결하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-12-15 08:03:14
원래의
142명이 탐색했습니다.

How to Resolve the

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿