> 데이터 베이스 > MySQL 튜토리얼 > 루프에서 SQL 변수 이름 충돌을 해결하는 방법은 무엇입니까?

루프에서 SQL 변수 이름 충돌을 해결하는 방법은 무엇입니까?

Patricia Arquette
풀어 주다: 2025-01-02 18:13:44
원래의
385명이 탐색했습니다.

How to Resolve SQL Variable Name Conflicts in Loops?

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

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