Warning: file_get_contents(/data/phpspider/zhask/data//catemap/8/linq/3.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/6/entity-framework/4.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/webpack/2.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
如何使用Linq和EF6(获取用户角色)查询联接表(多对多)_Linq_Entity Framework - Fatal编程技术网

如何使用Linq和EF6(获取用户角色)查询联接表(多对多)

如何使用Linq和EF6(获取用户角色)查询联接表(多对多),linq,entity-framework,Linq,Entity Framework,我有3个表:Users,UserRoles,UserRoleAssoc(联接表只包括UserID和UserRoleID)。实体框架在我的模型中没有显示userroleasociations,这似乎是正确的。我的目标是返回一个用户角色列表。如何获取所有UserRoles其中UserID=UserID 这就是我所拥有的,它看起来是正确的还是有更好的方法?我想我使用了从db更新模型时自动创建的导航属性 public IEnumerable<UserRole> GetUserRoles(in

我有3个表:
Users
UserRoles
UserRoleAssoc
(联接表只包括
UserID
UserRoleID
)。实体框架在我的模型中没有显示
userroleasociations
,这似乎是正确的。我的目标是返回一个用户角色列表。如何获取所有
UserRoles
其中
UserID
=UserID

这就是我所拥有的,它看起来是正确的还是有更好的方法?我想我使用了从db更新模型时自动创建的导航属性

public IEnumerable<UserRole> GetUserRoles(int userID)
{
    using (var ctx = new DataEntities())
    {
        var userroles = (from ur in ctx.UserRoles
                         from ura in ur.Users.Where(x => x.UserID == userID)
                              select ur).ToList();
        return userroles;
    }
}
public IEnumerable GetUserRoles(int-userID)
{
使用(var ctx=new DataEntities())
{
var userroles=(来自ctx.userroles中的ur
从ur.Users.Where中的ura(x=>x.UserID==UserID)
选择ur.ToList();
返回用户角色;
}
}

您的版本基本上是正确的,但它会使事情变得过于复杂

试一试

public IEnumerable GetUserRoles(int-userID)
{
使用(var ctx=new DataEntities())
{
返回ctx.Users.Where(x=>x.UserID==UserID)
.Select(x=>x.UserRoles.ToList())
.FirstOrDefault();
}
}

public IEnumerable GetUserRoles(int-userID)
{
使用(var ctx=new DataEntities())
{
返回ctx.UserRoles.Where(x=>x.Users.Any(y=>y.UserID==UserID))
.ToList();
}
}

等等,我就不能这样做吗?EF是否已经为我返回了一个用户角色?
User-User=User.GetByUserID(userID);UserRoles=user.UserRoles@user2272527当然,如果您只需要在获取用户时获取UserRoles。但是为了安全起见,您应该通过调用
var roles=user.UserRoles.ToList()
来执行查询。在幕后,在本例和我的第二个示例中执行的查询应该几乎相同。非常感谢!尽管在尝试user.UserRoles.ToList()时,我不断得到:EntityFramework.dll中发生了类型为“System.ObjectDisposedException”的异常,但在用户代码中未处理该异常,这是因为您试图在释放db上下文后访问导航属性。访问导航属性而不首先使用
Include()
扩展方法会触发另一个SQL查询,在释放上下文后执行该操作会触发该异常。
    public IEnumerable<UserRole> GetUserRoles(int userID)
    {
        using (var ctx = new DataEntities())
        {
            return ctx.Users.Where(x => x.UserID == userID)
                            .Select(x => x.UserRoles.ToList())
                            .FirstOrDefault();
        }
    }
    public IEnumerable<UserRole> GetUserRoles(int userID)
    {
        using (var ctx = new DataEntities())
        {
            return ctx.UserRoles.Where(x => x.Users.Any(y => y.UserID == userID))
                                .ToList();
        }
    }