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();

    结果:

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

  • 相关阅读:
    django页面分类和继承
    django前端从数据库获取请求参数
    pycharm配置django工程
    django 应用各个py文件代码
    CF. 1428G2. Lucky Numbers(背包DP 二进制优化 贪心)
    HDU. 6566. The Hanged Man(树形背包DP DFS序 重链剖分)
    小米邀请赛 决赛. B. Rikka with Maximum Segment Sum(分治 决策单调性)
    区间树 学习笔记
    CF GYM. 102861M. Machine Gun(主席树)
    2016-2017 ACM-ICPC East Central North America Regional Contest (ECNA 2016) (B, D, G, H)
  • 原文地址:https://www.cnblogs.com/lori/p/2518179.html
Copyright © 2011-2022 走看看