집 >데이터 베이스 >MySQL 튜토리얼 >'변수 이름 '@'이 이미 선언되었습니다.' SQL 오류를 해결하는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!