LINQ에서 엔터티까지 대소문자를 구분하지 않는 비교
LINQ to Objects와 달리 LINQ to Entities는 대/소문자 구분 비교를 직접 지원하지 않습니다. 이는 LINQ to Entities가 Lambda 표현식을 SQL 문으로 변환하여 궁극적으로 데이터베이스(예: SQL Server)에서 실행되기 때문입니다. 기본적으로 SQL Server는 대소문자를 구분하지 않는 데이터 정렬을 사용합니다. 즉, 다음 쿼리는 대소문자에 관계없이 항상 일치 항목을 반환합니다.
<code>context.Thingies.First(t => t.Name == "ThingamaBob");</code>
서버사이드 솔루션
LINQ to Entities에서 대소문자 구분 비교를 구현하려면 관련 열의 데이터베이스 데이터 정렬을 수정해야 합니다. 예를 들어, 다음 SQL 문은 "Thingies" 테이블에 있는 "Name" 열의 데이터 정렬을 대소문자를 구분하도록 변경합니다.
<code>ALTER TABLE Thingies ALTER COLUMN Name VARCHAR(25) COLLATE Latin1_General_CS_AS;</code>
클라이언트 솔루션
이상적이지는 않지만 LINQ to Entities와 LINQ to Objects를 모두 활용하는 클라이언트 측 해결 방법이 있습니다.
<code>var result = context.Thingies.Where(t => t.Name == "ThingamaBob") .AsEnumerable() .First(t => t.Name == "ThingamaBob");</code>
이 접근 방식에서 AsEnumerable()
는 쿼리를 메모리 내 열거형으로 변환하므로 Where()
을 사용하여 보조 대소문자 구분 비교를 수행할 수 있습니다. 그러나 이 해결 방법을 사용하면 데이터베이스에 추가 쿼리가 발생합니다.
위 내용은 LINQ에서 엔터티에 대한 대/소문자 구분 비교를 수행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!