2 fenglian0000 fenglian0000 于 2015.07.18 21:55 提问

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

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

3个回答

caozhy
caozhy   Ds   Rxr 2015.07.18 23:40

user已经是内存中的对象了,所以你执行的是linq to objects,不会去数据库查询。

fenglian0000
fenglian0000   2015.07.19 07:59

但是我用另外一个实体去做测试的时候是可以查询得到数据的

 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();
flesh222
flesh222   2015.07.21 10:17

U.ID =1 时 User 有Role

U.ID =2 时 User 木有关联的Role

Csdn user default icon
上传中...
上传图片
插入图片