/* github */
随笔 - 44  文章 - 0  评论 - 20  阅读 - 79880

监听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; //指定某个实体被修改过
posted on   王精灵  阅读(714)  评论(0)    收藏  举报
编辑推荐:
· 为什么PostgreSQL不自动缓存执行计划?
· 于是转身独立开发者
· C#.Net筑基-泛型T & 协变逆变
· dotnet 代码调试方法
· DbContext是如何识别出实体集合的
阅读排行:
· 免费开源 .NET OpenCV 迷你运行时全平台发布
· 10亿订单如何分库分表?
· 一个static关键字引发的线上故障:深度剖析静态变量与配置热更新的陷阱
· C# 的深度强化学习框架RL_Matrix
· 【Cursor保姆级教程】零基础小白从安装到实战,手把手教你玩转AI编程神器!
< 2025年7月 >
29 30 1 2 3 4 5
6 7 8 9 10 11 12
13 14 15 16 17 18 19
20 21 22 23 24 25 26
27 28 29 30 31 1 2
3 4 5 6 7 8 9

点击右上角即可分享
微信分享提示