asynchronous – EF6 – 将await关键字与Where()子句一起使用

前端之家收集整理的这篇文章主要介绍了asynchronous – EF6 – 将await关键字与Where()子句一起使用前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在使用实体框架6编写MVC 5 Internet应用程序,并且在使用.Where()子句时对使用await关键字有疑问.

这是我的代码有效:

public async Task<Account> GetAccount(string userName)
{
    if (Session[userName] == null)
    {
        Account account = db.accounts.Where(a => a.userName.Equals(userName)).FirstOrDefault();
        if (account == null)
        {
            //log out
            return null;
        }
        Session[userName] = account;
    }
    return Session[userName] as Account;
}

我想在检索Account对象时使用await关键字,如下所示:

Account account = await db.accounts.Where(a => a.userName.Equals(userName)).FirstOrDefault();

使用.Where()子句时是否可以使用await关键字?

提前致谢.

解决方法

await关键字只能用于返回“Task …”的方法,既没有.还有.FirstOrDefault(这是链中的最后一个方法,因此也就是await关键字适用的方法)return Task< IEnumerable的<帐户>> 从理论上讲,你可以编写自己的扩展方法,它只包含.Where和.FirstOrDefault方法. 此外,这个问题并不完全是EF特定的,而是一个“纯粹的”C#问题.
public static class ExtensionMethods
{
    public static async Task<IEnumerable<T>> WhereAsync<T>(this IEnumerable<T> source,Func<T,bool> selector)
    {
        return await Task.Run(() => source.Where(selector));
    }
}

虽然那会有点矫枉过正.

您可以将整个方法包装在一个Task中,因此您的最终代码将类似于:

public async Task<Account> GetAccount(string userName)
{
    return await Task.Run(() =>
    {
        if (Session[userName] == null)
        {
            Account account = db.accounts.Where(a => a.userName.Equals(userName)).FirstOrDefault();
            if (account == null)
            {
                //log out
                return null;
            }
            Session[userName] = account;
        }
        return Session[userName] as Account;
    });
}

猜你在找的Java相关文章