zoukankan      html  css  js  c++  java
  • Linq To Sql模式中自动生成TSQL增删改操作系列~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();

    结果:

    下回来说,如何去记录你修改的属性的值是什么,呵呵。

  • 相关阅读:
    runlevel=$(set -- $(runlevel); eval "echo $$#" )
    MPLS
    sql server 查询存储过程返回值
    sql 游标的关闭和释放
    sql 查询某一列最大的数据
    flex label如何通过AS3实现颜色设置
    sql server 字符串拆分
    Linux centos 解决"不在 sudoers 文件中。此事将被报告"的问题
    Flex String拼接
    flex 判断对象的类型
  • 原文地址:https://www.cnblogs.com/lori/p/2518179.html
Copyright © 2011-2022 走看看