zoukankan      html  css  js  c++  java
  • C#比较两个实体对象的属性值,如果其中一个对象的属性值为空,则把不为空的实体对象对应的属性值赋给它。


           TABSYSMEMBER member = new TABSYSMEMBER();//空的实体对象 TABSYSMEMBER oldMember = new TABSYSMEMBER();//非空实体对象 PropertyInfo[] p = member.GetType().GetProperties(); PropertyInfo[] ps1 = oldMember.GetType().GetProperties(); int value = 1; //foreach (PropertyInfo p in ps) //{ // value++; // p.SetValue(m, value.ToString(), null); //} ///下面将非空对象赋值 foreach (PropertyInfo p1 in ps1) { value++; p1.SetValue(oldMember, "aa"+value.ToString(), null); } //循环空实体对象 foreach (PropertyInfo pi in p) { //得到空实体对象的属性值---此句是重点 object o = member.GetType().GetProperty(pi.Name).GetValue(member, null); //得到非空实体对象对应属性的值 object o1 = oldMember.GetType().GetProperty(pi.Name).GetValue(oldMember, null); //如果空实体对象该属性值为空 if (o == null) { //则把非空实体对象的值赋给空实体对象的属性值 pi.SetValue(member, o1, null); } }

      

    说明:由于项目业务需要,需提供一个接口,功能为:由外部传来XML文档,解析成为实体对象,此实体对象有些值可能为空,需要把数据库查出来的旧数据赋上去,然后更新。

    提供了两个实体对象比较,为空并赋旧数据的功能。

    oldMember.GetType().GetProperty(pi.Name).GetValue(oldMember, null);
    此句是核心。

  • 相关阅读:
    计划任务
    swap
    fdisk
    raid 搭建
    Http协议中Cookie详细介绍
    linux系统日志以及分析
    搞清楚php-FPM到底是什么?
    Amoeba+Mysql实现数据库读写分离
    Last_SQL_Error: Error 'Can't drop database 'ABC'; database doesn't exist' on query. Default database: 'ABC'. Query: 'drop database ABC'
    MySQL主从失败, 错误Got fatal error 1236解决方法
  • 原文地址:https://www.cnblogs.com/m3Lee/p/3394453.html
Copyright © 2011-2022 走看看