EF core

   using (ZhaoxiDbContext context = new ZhaoxiDbContext())
            {
                {
                    /EFCore默认延迟执行---在需要结果的是才去按照需求加载数据到内存中;而不是把所有的数据都加载到内存中来;----提供性能的方法
                    //var jdQuery = context.JdCommodity001s.Where(j => j.Id < 30);
                    //foreach (var jd in jdQuery)
                    //{
                    //    Console.WriteLine(jd.Title);
                    //}
                    //var jdList = context.JdCommodity001s.Where(j => j.Id < 30).ToList();
                }

                {
                    // // JdCommodity001 jd1 = context.JdCommodity001s.FirstOrDefault(j => j.Id == 3); 
                    // Find 方法带有缓存机制;先回去内存中查找数据,如果内存中没有数据,才回去数据库中去获取数据;
                    //JdCommodity001 jd2 = context.JdCommodity001s.Find(3);
                }
                {
                    //JdCommodity001 jd1 = context.JdCommodity001s.FirstOrDefault(j => j.Id == 3); 
                    Linq查询每一次都会去数据库中查询数据;
                    //JdCommodity001 jd2 = context.JdCommodity001s.FirstOrDefault(j => j.Id == 3);
                    在查询的时候,尽量的选择Find查询,可以使用到缓存机制;;
                }
                {
                    //状态跟踪:实体对象对应的有一个副本在内存中,我们操作了这个实体对象以后,EFCore会自动和内存中的副本做比较;任何一次操作都会去和内存中的副本;-----损耗性能;----状态跟踪---损耗性能;
                    //如果我很明确,查询出来的数据,根本不需要做增删改;其实这个状态跟踪对我们来说就没有意义了;可以考虑使用AsNoTracking;去掉状态跟踪---提高性能;

                    //可以去掉状态的跟踪---提高性能; 
                    var jd3 = context.JdCommodity001s.FirstOrDefault(j => j.Id == 3);
                    var state = context.Entry<JdCommodity001>(jd3).State; 
                    var list = context.JdCommodity001s.Where(j => j.Id < 10).AsNoTracking().ToList(); //去掉状态耿跟踪; 
                    var state1= context.Entry<JdCommodity001>(list[0]).State;
                }
            }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值