首頁 > 後端開發 > C++ > 如何在 LINQ to Entities 中實現區分大小寫的比較?

如何在 LINQ to Entities 中實現區分大小寫的比較?

DDD
發布: 2025-01-21 17:41:09
原創
716 人瀏覽過

How to Achieve Case-Sensitive Comparisons in LINQ to Entities?

在 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中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板