欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

EF core

程序员文章站 2024-01-04 12:57:10
...
   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;
                }
            }

上一篇:

下一篇: