저장 프로시저 호출에 매개변수가 너무 많음
"프로시저 또는 함수 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!