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;
    });
}

相关文章

最近看了一下学习资料,感觉进制转换其实还是挺有意思的,尤...
/*HashSet 基本操作 * --set:元素是无序的,存入和取出顺序不...
/*list 基本操作 * * List a=new List(); * 增 * a.add(inde...
/* * 内部类 * */ 1 class OutClass{ 2 //定义外部类的成员变...
集合的操作Iterator、Collection、Set和HashSet关系Iterator...
接口中常量的修饰关键字:public,static,final(常量)函数...