首页 新闻 会员 周边 捐助

EF框架关于数据库两个关联的表操作的一些问题

0
[已关闭问题] 关闭于 2015-08-17 14:19

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

 


        
Opiece的主页 Opiece | 初学一级 | 园豆:195
提问于:2015-07-20 17:25
< >
分享
清除回答草稿
   您需要登录以后才能回答,未注册用户请先注册