监听EF执行的sql语句及状态
1、监听EF执行sql的方式
- db.Database.Log += c => Console.WriteLine($"sql:{c}");
- SQL Server Profiler
public JDDbContext() : base("name=JDDbContext") { this.Database.Log += c => Console.WriteLine($"sql:{c}"); }
2、查看EF对象上下文监听对象的状态
- db.Entry<User>(userNew).State
- db.Users.Where(u => u.Id == 21).AsNoTracking().FirstOrDefault(); //AsNoTracking() 函数用于设置当前操作不跟踪对象的状态,加一个可以提升性能
- db.Entry<User>(user).State = EntityState.Modified; //手动设置对象的状态
-
Find函数可以使用缓存,优先从内存查找(限于db),但是linq时不能用缓存,每次都是要查询的
- db.Entry<User>(user5).Property("Name").IsModified = true;//指定某字段被改过
- db.Entry<User>(user).State = EntityState.Modified; //指定某个实体被修改过
欢迎评论留言交流
分类:
.Net
【推荐】FlashTable:表单开发界的极速跑车,让你的开发效率一路狂飙
【推荐】Flutter适配HarmonyOS 5知识地图,实战解析+高频避坑指南
【推荐】博客园的心动:当一群程序员决定开源共建一个真诚相亲平台
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 为什么PostgreSQL不自动缓存执行计划?
· 于是转身独立开发者
· C#.Net筑基-泛型T & 协变逆变
· dotnet 代码调试方法
· DbContext是如何识别出实体集合的
· 免费开源 .NET OpenCV 迷你运行时全平台发布
· 10亿订单如何分库分表?
· 一个static关键字引发的线上故障:深度剖析静态变量与配置热更新的陷阱
· C# 的深度强化学习框架RL_Matrix
· 【Cursor保姆级教程】零基础小白从安装到实战,手把手教你玩转AI编程神器!