在 LINQ to Entities 中實現區分大小寫的比較
LINQ to Entities 查詢(如 Thingies.First(t => t.Name == "ThingamaBob")
)預設可能不區分大小寫。 這是由於 LINQ to Entities 將 Lambda 表達式轉換為 SQL,其中區分大小寫取決於 SQL Server 資料庫的排序規則設定。
資料庫層級解決方案:修改排序規則
確保區分大小寫比較的最有效方法是將列的排序規則變更為區分大小寫的選項。 例如,要讓 Name
表中的 Thingies
欄位區分大小寫,請使用下列 SQL 指令:
<code class="language-sql">ALTER TABLE Thingies ALTER COLUMN Name VARCHAR(25) COLLATE Latin1_General_CS_AS</code>
客戶端方法:利用 LINQ to Objects
如果修改資料庫排序規則不可行,則使用 LINQ to Objects 的客戶端解決方案提供了替代方案。這涉及初始資料庫查詢,然後使用 AsEnumerable()
進行記憶體中比較。 例:
<code class="language-csharp">Thingies.Where(t => t.Name == "ThingamaBob") .AsEnumerable() .First(t => t.Name == "ThingamaBob");</code>
這會在初始資料庫過濾後在記憶體中執行區分大小寫的檢查。 請注意,此方法的效能可能低於伺服器端排序規則變更。
以上是如何在 LINQ to Entities 中實現區分大小寫的比較?的詳細內容。更多資訊請關注PHP中文網其他相關文章!