我正在使用实体框架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; }); }