自定义ORM系列(二)发现属性是否修改,有选择的持久化
引言
今天给大家介绍的是ORM中的有选择持久化技术。现在的很多ORM工具都支持有选择的持久化,就是对于属性有选择的持久化。也可以理解为只持久化那些有变化的属性,忽略没有变化的属性。
正文
很多时候我们想要知道实体的那些属性被更新,那些属性没有变化。
在很多的ORM工具中,在持久化数据的时候,可以判断哪些属性有值,哪些属性被更新过,这样的属性才会被持久化,没有动过的属性不会被持久化,而不是所有的属性都持久化。
发现属性有变化,有很多种办法。今天我给大家介绍一种,利用Inotifypropertychanged接口来实现属性变化的跟踪。一个类如果实现了这个接口,就可以跟踪属性的变化,然后定义一个集合,把发生变化的属性记录下来。这样,在持久化的时候,就可以针对变化的属性进行有选择性的持久化了。
Person?public?class?Person
????{
????????public?Guid?ID?{?get;?set;?}
????????public?string?Name?{?get;?set;?}
????????public?string?Username?{?get;?set;?}
????}
????public?enum?PersonStatus
????{
????????///?<summary>
????????///?正常
????????///?</summary>
????????Normal,
????????///?<summary>
????????///?挂起
????????///?</summary>
????????Suspend,
????????///?<summary>
????????///?审核
????????///?</summary>
????????Auditing
????}
?
?
一个用户信息,有一个属性是用户状态。用户在注册之后,可以提交申请,然后管理员审核用户。用户可以更新个人的其他信息(除去状态)。这个需求里面包含两个个更新的方法,一个是用户更新个人信息,一个是管理员审核用户信息,需要更新用户状态。
要么写两个存储过程,或者是两个TSQL语句。如果实体实现了INotifyPropertyChanged,按照我上面的方法,就保留一个Update方法就可以了,给PersonPo赋值几个属性,将来就只是更新几个属性,是不是可以简化这个过程呢?反正我这里就有这样的需求,还不少呢?开始我也没有用这个方法,最近才想出来的。不知道各位如何认为呢?
希望提出更好好的意见。