0

我在学生和教授 (_students_selected) 之间的数据库(带有桥接表)中建模了一个多对多关系,在我的实体中,我将其建模为多对多关系,即教授有很多学生。

HasManyToMany(x => x.Students)
   .Table("_students_selected").ChildKeyColumn("student_key").ParentKeyColumn("professor_key");

public class Professor    
{
        private IList<Students> _students;
        public virtual Student Students
        {
            get { return _students; }
            set { _students = value; }
        }
}

我无法查询教授的学生,我尝试了以下方法,但是 nhibernate 无法识别 Any 来过滤列表。什么等价于任何?

_unitOfWork.Session.QueryOver<Professor>()
   .Where(x => x.Students.Any(i => i.Id.IsIn(childStudentList))).List();
4

1 回答 1

1

这帮助我解决了一个类似的问题:nhibernate queryover not eagerly loading with a many to many joinalias

我能够将其减少到:

Role role = null;

session.QueryOver<User>()
    .JoinAlias(u => u.Roles, () => role)
    .Where(() => role.Id == someId);
于 2012-02-03T01:00:00.253 回答