Linq To Sql模式中自动生成T-SQL增删改操作系列~PropertyChanged事件实现在子类中记录属性的变化,在基类中进行统一处理
通过linq to sql生成的实体,有一些特性,这些特性就包括今天要用的 PropertyChanged和PropertyChanging这两个事件,它们分别记录了实体属性在修改前与修改后的事件变化,
有时,我们使用linq to sql或EF去做为底层ORM时,在更新和删除操作时,总觉得性能不如T-SQL来的快,但LINQ TO SQL用起来实在比T-SQL要方便,这时,你是否有个想法,这T—SQL是否可以根据我们的要求自己生成呢,答案是肯定的,今天讲的就讲一个实现这种操作的基础知识
1 /// <summary> 2 /// 实体基类 3 /// </summary> 4 public abstract class EntityBase 5 { 6 public Dictionary<string, object> PropertyChangedList = new Dictionary<string, object>(); 7 protected void Entity_PropertyChanged(object sender, PropertyChangedEventArgs e) 8 { 9 PropertyChangedList.Add(e.PropertyName, null); 10 } 11 } 12 /// <summary> 13 /// 产品类 14 /// </summary> 15 public partial class Product : EntityBase 16 { 17 #region 导航属性 18 public Category Category_Extend { get; set; } 19 public virtual IEnumerable<Product_Property_R> Product_Property_R_Extend { get; set; } 20 #endregion 21 22 #region 分部方法 23 partial void OnCreated() 24 { 25 this.PropertyChanged += new PropertyChangedEventHandler(base.Entity_PropertyChanged); 26 } 27 #endregion 28 29 }
测试:
1 Product p = new Product { CategoryID = 2, CreateDate = DateTime.Now }; 2 p.PropertyChangedList.ToList().ForEach(i => Console.WriteLine(i)); 3 4 Console.ReadKey();
结果:
下回来说,如何去记录你修改的属性的值是什么,呵呵。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 记一次.NET内存居高不下排查解决与启示
2011-05-25 说说面向对象的故事,主人是人类!(二)