当前位置:  开发笔记 > 编程语言 > 正文

将DbSet和查询结果分配给同一个变量

如何解决《将DbSet和查询结果分配给同一个变量》经验,为你挑选了1个好方法。

我使用以下代码允许用户搜索其他注册用户,以便将其添加到朋友列表:

[Authorize(Roles = "RegisteredUsers")]
public ActionResult Index(string searchString)
{
    //list of registered users
    var regUsers = db.Users;

    if (!String.IsNullOrEmpty(searchString))
    {
        regUsers = regUsers.Where(s => s.User.LastName.Contains(searchString));
    }

    return View(regUsers.ToList());
}

然而,我在第9行得到一个错误regUsers = regUsers.Where(..),说:

"无法隐式将类型转换System.Linq.IQueryableSystem.Data.entity.DbSet

我该如何重用regUsers变量?



1> Igor Ralic..:

怎么样

IQueryable regUsers = db.Users;

db.Users属于DbSet类型,因此当您进行Where调用时,它会尝试隐式分配不同类型的值regUsers,这不起作用 - 因此出错.

编辑:正如其他人所指出的,AsQueryable可以省略调用.regUsers现在显式为IQueryable类型.


那么,首先转换为`IQueryable`而不是`List`?我不建议这样做.
推荐阅读
惬听风吟jyy_802
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有