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

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

Linda Hamilton
Linda Hamilton원래의
2024-12-30 14:08:10727검색

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.