>백엔드 개발 >C++ >CommandType이 텍스트인 경우 OleDbCommand 매개변수 순서가 중요합니까?

CommandType이 텍스트인 경우 OleDbCommand 매개변수 순서가 중요합니까?

DDD
DDD원래의
2024-12-30 17:46:12169검색

Does OleDbCommand Parameter Order Matter When CommandType is Text?

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

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