在EF创建两个多对多关联的实体,并且映射到数据库中,在对中间表进行查询或是清除中间表的数据时操作失败,使用数据库跟踪发现没有生成相应的代码
static void Main(string[] args) { OAMangerEntities db = new OAMangerEntities(); var user = db.CreateObjectSet<UserInfo>().Where(u => u.ID == 2).FirstOrDefault();//查询出User的信息 //user.Role.Clear();//当中间变没有数据的时候可以插入数据,但是这句代码无法清除数据库中关联表中的数据 var role = db.CreateObjectSet<Role>().Where(r => r.ID == 2).FirstOrDefault();//查询出role的信息 ////user.Role.Add(role); //test.SaveChanges(); /*******************************/ //这段代码在使用数据库跟踪查询时没有生成相应的SQL语句,一直调试找不出原因!!!!! var s = (from r in user.Role select r.ID).ToList(); /******************************/ Console.WriteLine("ok"); Console.ReadKey();
但是我用另外一个实体去做测试的时候是可以查询得到数据的
TestContainer test = new TestContainer(); var user = test.CreateObjectSet<User>().Where(u => u.ID == 1).FirstOrDefault(); // user.Role.Clear(); var role = test.CreateObjectSet<Role>().Where(r => r.ID == 1).FirstOrDefault(); // user.Role.Add(role); //test.SaveChanges(); /*******************************/ //这在数据库中是有生成SQL语句的,也可以查询得到相应的关联表的数据 var s = (from r in user.Role select r.ID).ToList();