OleDbCommand 매개변수 순서 및 우선순위: 잘못 정렬된 기대의 사례
OleDbCommand를 사용하여 쿼리를 구성할 때 매개변수 순서를 정확하게 확인하는 것이 중요합니다. SQL 문의 순서를 따릅니다. 일반적인 오해는 명명된 매개 변수가 이 요구 사항을 제거한다는 가정을 중심으로 이루어집니다. 그러나 심층 디버깅 세션에서 밝혀진 바와 같이 OleDbCommand는 CommandType이 Text로 설정된 경우 명명된 매개 변수에 대한 지원이 부족합니다.
주어진 예에서:
SELECT * FROM tblSomeThing WHERE id = @id AND debut = @dtDebut AND fin = @dtFin
매개 변수는 다음에 추가됩니다. 다음 순서:
cmd.Parameters.Add("@id", OleDbType.Integer).Value = idSociete; cmd.Parameters.Add("@dtFin", OleDbType.Date).Value = dateTraitementFin; cmd.Parameters.Add("@dtDebut", OleDbType.Date).Value = dateTraitementDebut;
그러나 결과가 반환되지 않아 불일치를 나타냅니다. SQL 문과 일치하도록 매개 변수를 다시 정렬하면 쿼리가 성공적으로 실행됩니다.
cmd.Parameters.Add("@id", OleDbType.Integer).Value = idSociete; cmd.Parameters.Add("@dtDebut", OleDbType.Date).Value = dateTraitementDebut; cmd.Parameters.Add("@dtFin", OleDbType.Date).Value = dateTraitementFin;
이는 http://msdn.microsoft.com/en-us/library/system.data의 설명서와 일치합니다. oledb.oledbcommand.parameters.aspx는 OleDbCommand가 텍스트 모드의 SQL 문에 대해 명명된 매개 변수를 지원하지 않음을 명시적으로 나타냅니다. 대신 물음표(?) 자리 표시자를 사용해야 하며 컬렉션의 OleDbParameter 개체 순서는 명령 텍스트의 위치와 엄격하게 일치해야 합니다.
위 내용은 CommandType이 텍스트인 경우 OleDbCommand 매개변수 순서가 중요합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!