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;
}
}