SQL 변수 이름 충돌
SQL 문 실행 시 변수 이름이 이미 선언되었다는 오류 메시지가 나타날 수 있습니다. 쿼리 일괄 처리 또는 저장 프로시저 내에서 고유해야 합니다. 이는 동일한 이름을 가진 여러 매개변수가 루프에 추가되는 상황에서 발생할 수 있습니다.
예를 들어 다음 코드 조각을 고려하세요.
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; 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(); }
이 코드에서 @LockState 변수는 루프 내에서 SQL 명령의 매개변수에 여러 번 추가됩니다. 이는 변수 이름이 고유해야 한다는 규칙을 위반하는 것입니다.
이 문제를 해결하려면 루프 외부에 매개변수를 추가한 다음 루프 내에서 해당 값을 업데이트하거나 나중에 매개변수.Clear() 메서드를 사용할 수 있습니다. 각 루프 반복을 통해 이전에 추가된 매개변수를 제거합니다.
다음은 매개변수 외부에 매개변수를 추가하는 예입니다. 루프:
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; rwd.command.Parameters["@LockState"].Value = 1; rwd.command.Parameters["@card_descr"].Value = txt_desc2.Text; rwd.connection.Open(); rwd.command.ExecuteScalar(); rwd.connection.Close(); }
또는 루프 내에서 매개변수.Clear()를 사용할 수 있습니다.
for (long counter = from; counter <= to; counter++) { 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(); }
SQL 매개변수 내에서 고유한 변수 이름을 보장함으로써 변수 선언 충돌을 방지할 수 있습니다. 귀하의 진술을 성공적으로 실행하십시오.
위 내용은 루프에서 SQL 변수 이름 충돌을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!