您的位置:首页 > 数据库 > SQL

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

2012-05-25 15:54 721 查看
通过linq to sql生成的实体,有一些特性,这些特性就包括今天要用的 PropertyChanged和PropertyChanging这两个事件,它们分别记录了实体属性在修改前与修改后的事件变化,

有时,我们使用linq to sql或EF去做为底层ORM时,在更新和删除操作时,总觉得性能不如T-SQL来的快,但LINQ TO SQL用起来实在比T-SQL要方便,这时,你是否有个想法,这T—SQL是否可以根据我们的要求自己生成呢,答案是肯定的,今天讲的就讲一个实现这种操作的基础知识

/// <summary>
/// 实体基类
/// </summary>
public abstract class EntityBase
{
public Dictionary<string, object> PropertyChangedList = new Dictionary<string, object>();
protected void Entity_PropertyChanged(object sender, PropertyChangedEventArgs e)
{
PropertyChangedList.Add(e.PropertyName, null);
}
}
/// <summary>
/// 产品类
/// </summary>
public partial class Product : EntityBase
{
#region 导航属性
public Category Category_Extend { get; set; }
public virtual IEnumerable<Product_Property_R> Product_Property_R_Extend { get; set; }
#endregion

#region 分部方法
partial void OnCreated()
{
this.PropertyChanged += new PropertyChangedEventHandler(base.Entity_PropertyChanged);
}
#endregion

}


测试:

Product p = new Product { CategoryID = 2, CreateDate = DateTime.Now };
p.PropertyChangedList.ToList().ForEach(i => Console.WriteLine(i));

Console.ReadKey();


结果:



下回来说,如何去记录你修改的属性的值是什么,呵呵。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐