Lose.zhang 发表于 2012-12-10 14:14:50

Linq To Sql模式中自动生成T-SQL增删改操作系列~PropertyChanged事件实现在子类中记录属性的变化,在基类中进行统一处理

<div id="cnblogs_post_body">通过linq to sql生成的实体,有一些特性,这些特性就包括今天要用的PropertyChanged和PropertyChanging这两个事件,它们分别记录了实体属性在修改前与修改后的事件变化,
有时,我们使用linq to sql或EF去做为底层ORM时,在更新和删除操作时,总觉得性能不如T-SQL来的快,但LINQ TO SQL用起来实在比T-SQL要方便,这时,你是否有个想法,这T—SQL是否可以根据我们的要求自己生成呢,答案是肯定的,今天讲的就讲一个实现这种操作的基础知识
<div class="cnblogs_code"> 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 : EntityBase16     {17         #region 导航属性18         public Category Category_Extend { get; set; }19         public virtual IEnumerable<Product_Property_R> Product_Property_R_Extend { get; set; }20         #endregion21 22         #region 分部方法23         partial void OnCreated()24       {25             this.PropertyChanged += new PropertyChangedEventHandler(base.Entity_PropertyChanged);26       }27         #endregion28 29   }
页: [1]
查看完整版本: Linq To Sql模式中自动生成T-SQL增删改操作系列~PropertyChanged事件实现在子类中记录属性的变化,在基类中进行统一处理