> 데이터 베이스 > MySQL 튜토리얼 > 저장 프로시저에서 전역 입력 매개 변수를 사용할 때 '스칼라 변수 '@RowFrom'을 선언해야 합니다' 오류를 수정하는 방법은 무엇입니까?

저장 프로시저에서 전역 입력 매개 변수를 사용할 때 '스칼라 변수 '@RowFrom'을 선언해야 합니다' 오류를 수정하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-12-17 00:24:25
원래의
904명이 탐색했습니다.

How to Fix

"@RowFrom" 및 "@RowTo" 전역 입력 매개변수를 사용하여 컴파일 오류 해결

저장 프로시저에서 전역 입력 매개변수를 선언하는 것은 다음과 같습니다. 절차 내에서 사용하는 데 필요합니다. 그러나 "Exec(@sqlstatement)"를 사용하여 저장 프로시저 내에서 컴파일된 SQL 쿼리를 실행할 때 "@RowFrom" 또는 "@RowTo" 입력 매개 변수가 다음과 같은 경우 "스칼라 변수 '@RowFrom'을 선언해야 합니다"라는 오류가 발생할 수 있습니다. 올바르게 선언되거나 사용되지 않았습니다.

제공된 오류 메시지는 "@RowFrom" 변수가 선언되지 않았음을 나타냅니다. 이 문제를 해결하려면 SQL 쿼리에서 참조하기 전에 저장 프로시저 내에서 "@RowFrom" 및 "@RowTo"를 스칼라 변수로 명시적으로 선언하십시오.

또한 "@RowTo" 값을 연결을 사용하여 새 변수를 만들려면 변수 유형이 적절하게 변환되었는지 확인하세요. 잘못된 구문 대신

SET @Rt = ' + @RowTo
로그인 후 복사

"@RowTo"를 문자열로 변환하는 올바른 구문을 사용하세요.

SET @Rt = ' + CONVERT(VARCHAR(12), @RowTo)
로그인 후 복사

최신 버전의 SQL Server는 CONCAT() 함수를 지원합니다. 이러한 작업을 단순화합니다.

SET @sql = N'SELECT ' + CONVERT(varchar(12), @RowTo) + ' * 5';
로그인 후 복사

그러나 SQL 주입에 대한 보안을 강화하려면 대신 매개변수화된 SQL 문을 사용하는 것이 좋습니다. 연결의. 여기에는 다음 예와 같이 입력 매개변수를 SQL 쿼리에 명시적으로 전달하는 작업이 포함됩니다.

SET @sql = @sql + ' WHERE RowNum BETWEEN @RowFrom AND @RowTo;';

EXEC sys.sp_executesql @sql,
  N'@RowFrom int, @RowTo int',
  @RowFrom, @RowTo;
로그인 후 복사

위 내용은 저장 프로시저에서 전역 입력 매개 변수를 사용할 때 '스칼라 변수 '@RowFrom'을 선언해야 합니다' 오류를 수정하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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