首頁 > 後端開發 > C++ > 如何使用 Linq to Entities 中的 Contains() 函數?

如何使用 Linq to Entities 中的 Contains() 函數?

Susan Sarandon
發布: 2024-10-29 11:14:29
原創
575 人瀏覽過

How to Use the Contains() Function in Linq to Entities?

使用Linq to Entities 的Contains() 函數解決方法

問題:

如何使用Linq to Entities 查詢中的Contains() 函數,儘管缺乏支援?

答案:

更新: 從 Entity Framework 開始( EF) 版本 4 及更高版本,直接支援 Contains()。

對於早期版本的EF,需要解決方法:

Contains() 的自訂擴充方法

建立下列擴充方法:

<code class="csharp">public static IQueryable<TEntity> WhereIn<TEntity, TValue>(
    this ObjectQuery<TEntity> query,
    Expression<Func<TEntity, TValue>> selector,
    IEnumerable<TValue> collection)
{
    // ... (implementation remains the same as in the provided code)
}</code>
登入後複製

選用靜態集合版本

您可以選擇建立一個允許靜態集合的版本:輸入:

<code class="csharp">public static IQueryable<TEntity> WhereIn<TEntity, TValue>(
    this ObjectQuery<TEntity> query,
    Expression<Func<TEntity, TValue>> selector,
    params TValue[] collection)
{
    return WhereIn(query, selector, (IEnumerable<TValue>)collection);
}</code>
登入後複製

用法:

使用此擴充方法,您可以在Linq to Entities 查詢中使用Contains(),如下所示:

<code class="csharp">public static void Main()
{
    using (MyObjectContext context = new MyObjectContext())
    {
        // Using method 1 - collection provided as collection
        var contacts1 = context.Contacts.WhereIn(c => c.Name, GetContactNames());

        // Using method 2 - collection provided statically
        var contacts2 = context.Contacts.WhereIn(c => c.Name,
            "Contact1",
            "Contact2",
            "Contact3",
            "Contact4");
    }
}</code>
登入後複製

以上是如何使用 Linq to Entities 中的 Contains() 函數?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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