> 데이터 베이스 > MySQL 튜토리얼 > '변수 이름 '@'이 이미 선언되었습니다.' SQL 오류를 해결하는 방법은 무엇입니까?

'변수 이름 '@'이 이미 선언되었습니다.' SQL 오류를 해결하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-30 14:08:10
원래의
711명이 탐색했습니다.

How to Resolve the

변수 이름 '@'이(가) 이미 선언되었습니다: 매개 변수 중복 해결

SQL 코드를 실행하려고 하면 "변수 이름이 '@'입니다. LockState'가 이미 선언되었습니다. 변수 이름은 쿼리 일괄 처리 또는 저장 프로시저 내에서 고유해야 합니다." 이 문제는 루프에 동일한 매개변수의 여러 인스턴스가 포함되어 발생합니다.

이 오류를 해결하려면 각 루프 반복 후에 매개변수를 지우거나 루프 앞에 매개변수를 추가할 수 있습니다.

각 루프 반복 후 매개변수 지우기

for (long counter = from; counter <= to; counter++) {
    // Clear parameters before adding new ones
    rwd.command.Parameters.Clear();

    string upd = "update card set LockState=@lockstate, card_descr=@card_descr where [cardNumber] = N'{0}'";
    rwd.command.CommandText = upd;
    rwd.command.Parameters.Add(new SqlParameter("@LockState", SqlDbType.NVarChar)).Value = 1;
    rwd.command.Parameters.Add(new SqlParameter("@card_descr", SqlDbType.NVarChar)).Value = txt_desc2.Text;
    rwd.connection.Open();
    rwd.command.ExecuteScalar();
    rwd.connection.Close();
}
로그인 후 복사

루프 전에 매개변수 추가 및 루프 내에 값 할당 루프

rwd.command.Parameters.Add(new SqlParameter("@LockState", SqlDbType.NVarChar));
rwd.command.Parameters.Add(new SqlParameter("@card_descr", SqlDbType.NVarChar));

for (long counter = from; counter <= to; counter++) {
    string upd = "update card set LockState=@lockstate, card_descr=@card_descr where [cardNumber] = N'{0}'";
    rwd.command.CommandText = upd;

    // Assign values to parameters within the loop
    rwd.command.Parameters["@LockState"].Value = 1;
    rwd.command.Parameters["@card_descr"].Value = txt_desc2.Text;

    rwd.connection.Open();
    rwd.command.ExecuteScalar();
    rwd.connection.Close();
}
로그인 후 복사

이러한 솔루션 중 하나를 구현하면 매개변수 중복 문제를 효과적으로 해결하고 SQL 코드의 성공적인 실행을 보장할 수 있습니다.

위 내용은 '변수 이름 '@'이 이미 선언되었습니다.' SQL 오류를 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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