在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();