> 데이터 베이스 > MySQL 튜토리얼 > '인수가 너무 많이 지정되었습니다'라는 메시지와 함께 저장 프로시저 호출이 실패하는 이유는 무엇입니까?

'인수가 너무 많이 지정되었습니다'라는 메시지와 함께 저장 프로시저 호출이 실패하는 이유는 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-27 08:06:09
원래의
366명이 탐색했습니다.

Why Does My Stored Procedure Call Fail with

저장 프로시저 호출에 매개변수가 너무 많음

"프로시저 또는 함수 xxx에 인수가 너무 많이 지정됨" 오류 메시지는 숫자가 일치하지 않음을 나타냅니다. 저장 프로시저 호출에 지정된 매개변수 수와 저장 프로시저 정의에 선언된 매개변수 수입니다.

이 특별한 경우에는 저장 프로시저 "[dbo].[M_UPDATES]"를 호출하면 다른 저장 프로시저 "[etl_M_Update_Promo]"가 호출됩니다. "[etl_M_Update_Promo]"가 하나의 매개변수 @GenId만 허용하도록 선언되었지만 "[dbo].[M_UPDATES]"의 호출에서 두 개의 매개변수(@GenID 및 @Description)를 전달하기 때문에 오류가 발생합니다.

불일치 매개변수 식별

정확한 불일치를 식별하려면 저장 프로시저 "[etl_M_Update_Promo]"의 선언:

ALTER PROCEDURE [etl].[etl_M_Update_Promo]
@GenId bigint = 0
as
로그인 후 복사

이 선언은 프로시저가 bigint 데이터 유형이고 기본값이 0인 하나의 매개 변수 @GenId를 사용하도록 지정합니다. "[dbo].[M_UPDATES]"에서 호출하면 두 개의 매개 변수를 전달하지만 두 번째 매개 변수(@Description)가 프로시저 정의에 선언되지 않아 다음이 발생합니다. 오류.

매개변수 목록 조정

오류를 해결하려면 두 번째 매개변수를 포함하도록 "[etl_M_Update_Promo]" 선언을 수정해야 합니다.

ALTER PROCEDURE [etl].[etl_M_Update_Promo]
@GenId bigint = 0,
@Description NVARCHAR(50)
AS 

.... Rest of your code.
로그인 후 복사

프로시저 선언에서 @Description을 추가 매개변수로 지정하면 이제 다음 경우에 합법적으로 전달할 수 있습니다. "[dbo].[M_UPDATES]"에서 "[etl_M_Update_Promo]"를 호출합니다.

위 내용은 '인수가 너무 많이 지정되었습니다'라는 메시지와 함께 저장 프로시저 호출이 실패하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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