> 데이터 베이스 > MySQL 튜토리얼 > 내 SQL 저장 프로시저에서 '프로시저 또는 함수 '...'에 '@parameter name' 매개변수가 제공되지 않았습니다.' 오류가 발생하는 이유는 무엇입니까?

내 SQL 저장 프로시저에서 '프로시저 또는 함수 '...'에 '@parameter name' 매개변수가 제공되지 않았습니다.' 오류가 발생하는 이유는 무엇입니까?

Barbara Streisand
풀어 주다: 2025-01-06 16:50:40
원래의
343명이 탐색했습니다.

Why Does My SQL Stored Procedure Throw a

저장 프로시저 또는 함수에 제공된 것으로 알려진 매개 변수가 필요한 경우

SQL Server 데이터베이스에 데이터를 삽입하기 위해 저장 프로시저를 호출할 때 다음과 같은 문제가 발생할 수 있습니다. "프로시저 또는 함수 ' 저장 프로시저 이름 '에 제공되지 않은 '@parameter name' 매개 변수가 필요합니다." 이 오류 메시지는 특히 저장 프로시저에 올바른 매개변수가 있고 해당 매개변수가 코드에 제공되고 있음을 확인한 경우 혼란스러울 수 있습니다.

오류 문제 해결

이 문제를 해결하려면 다음 사항을 철저히 검토하세요.

  • 매개변수 이름 및 데이터 유형: 코드의 매개변수 이름과 데이터 유형이 저장 프로시저에 정의된 것과 정확히 일치하는지 확인하세요. 동일한 대소문자를 사용하고 오타를 피하십시오.
  • 명령 유형 확인: 저장 프로시저를 호출하고 있음을 명시적으로 나타내려면 명령 유형을 StoredProcedure로 지정하십시오. 이 설정을 생략하면 실행 중인 명령이 모호해질 수 있습니다.
  • 기본값 비활성화: 저장 프로시저의 매개변수에 대해 기본값이 정의된 경우 코드에서 명시적으로 지정해야 합니다. 사용자 정의 값을 제공하고 싶지 않은 경우에도 마찬가지입니다.
  • 매개변수 순서: 코드에서 매개변수의 순서는 다음과 같습니다. 저장 프로시저에 정의된 순서와 일치합니다. 매개변수가 누락되거나 순서가 잘못된 경우 오류가 발생합니다.

샘플 코드 업데이트

다음은 매개변수를 명시적으로 지정하는 업데이트된 버전의 코드입니다. 명령 유형 및 매개변수 값:

public void SHOWuser(string userName, string password, string emailAddress, List<int> preferences)
{
    using var dbcon = new SqlConnection(conn);
    using var cmd = new SqlCommand();

    cmd.Connection = dbcon;
    cmd.CommandType = System.Data.CommandType.StoredProcedure;
    cmd.CommandText = "SHOWuser";

    cmd.Parameters.AddWithValue("@userName", userName);
    cmd.Parameters.AddWithValue("@password", password);
    cmd.Parameters.AddWithValue("@emailAddress", emailAddress);

    dbcon.Open();
    int i = Convert.ToInt32(cmd.ExecuteScalar());

    cmd.Parameters.Clear();
    cmd.CommandText = "tbl_pref";

    foreach (int preference in preferences)
    {
        cmd.Parameters.Clear();
        cmd.Parameters.AddWithValue("@userID", Convert.ToInt32(i));
        cmd.Parameters.AddWithValue("@preferenceID", Convert.ToInt32(preference));

        cmd.ExecuteNonQuery();
    }
}
로그인 후 복사

매개변수 이름, 데이터 유형, 명령 유형 및 매개변수를 주의 깊게 검사하여 주문하면 이 오류를 완화하고 저장 프로시저를 성공적으로 실행할 수 있습니다.

위 내용은 내 SQL 저장 프로시저에서 '프로시저 또는 함수 '...'에 '@parameter name' 매개변수가 제공되지 않았습니다.' 오류가 발생하는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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