加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Java > 正文

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

发布时间:2020-12-14 23:59:15 所属栏目:Java 来源:网络整理
导读:我正在使用实体框架6编写MVC 5 Internet应用程序,并且在使用.Where()子句时对使用await关键字有疑问. 这是我的代码有效: public async TaskAccount GetAccount(string userName){ if (Session[userName] == null) { Account account = db.accounts.Where(a
我正在使用实体框架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;
    });
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读