首页 >后端开发 >C++ >如何使用 Linq to Entities 中的 Contains() 函数?

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

Susan Sarandon
Susan Sarandon原创
2024-10-29 11:14:29575浏览

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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn