C#获取EF实体对象或自定义属性类的字段名称和值

简介: 原文:C#获取EF实体对象或自定义属性类的字段名称和值在年前上班的时候遇到了一个问题是这样描述的:我前台设计一个页面,是标签和文本框,当用户修改了哪个文本框的值,将该修改前的值、修改后的值,该值对应的字段,该值对应的行id获取到保存到数据库的某张表里。
原文: C#获取EF实体对象或自定义属性类的字段名称和值

在年前上班的时候遇到了一个问题是这样描述的:我前台设计一个页面,是标签和文本框,当用户修改了哪个文本框的值,将该修改前的值、修改后的值,该值对应的字段,该值对应的行id获取到保存到数据库的某张表里。现在数据库有一张表,结构如下:

ID   修改行ID 修改列名称 修改前的值 修改后的值 所属修改批次 修改时间
1   1 test 10 11 2013-10-11 第一批次 2013-10-11

思路:

1、将数据封装成实体对象传到后台。整套下来是用MVC的机制实现的

2、利用反射。获取对象的字段名称、修改前的值、修改后的值

3、调用保存方法。将修改记录保存到数据库。

4、下面贴上主要实现代码,里面包含设计实现思路:

 1             //判断字段是否修改(原值、旧值做比较),student为前台传入的数据对象
 2             var oldModel = this.db.Students.Where(p => p.ID == student.ID).FirstOrDefault();
 3             if (oldModel == null)
 4             {
 5                 return "返回数据为空!";
 6             }
 7 
 8             //获取当前对象的属性数组
 9             PropertyInfo[] currentPro = student.GetType().GetProperties();
10             //获取原始对象的属性数组
11             PropertyInfo[] oldPro = oldModel.GetType().GetProperties();
12             foreach (PropertyInfo old in oldPro)
13             {
14                 foreach (PropertyInfo curtrent in currentPro.
15                     Where(p => !string.IsNullOrEmpty(p.Name))
16                 {
17                     //获取当前数据
18                     object currentColumnValue = curtrent.GetValue(student, null);
19                     //获取原始数据
20                     object oldColumnValue = old.GetValue(oldModel, null);
21 
22                     //判断值是否相等
23                     if (currentColumnValue.ToString() != oldColumnValue.ToString())
24                     {
25                         //保存新值/旧值到数据库
26                         SaveStudentLog(oldModel.ID, oldColumnValue.ToString(), currentColumnValue.ToString(), old.Name);
27                         break;
28                     }
29                 }
30             }
通过反射获取对象包含的字段名称和值
 1  private void SaveStudentLog(int id, string oldValue, string currentValue, string column)
 2         {
 3             StudentLog studentLog = new StudentLog();
 4             var student = this.db.Students.Where(p => p.ID == id).FirstOrDefault();
 5             if (student == null)
 6             {
 7                 return;
 8             }
 9 
10             studentLog.Student = student;
11             studentLog.ValueOfOld = oldValue.Trim();
12             studentLog.ValueOfNew = currentValue.Trim();
13             studentLog.FieldName = column;
14             studentLog.FieldDesc = "1223";
15             studentLog.UserAccount = "123";
16             studentLog.UserRoleName = "34";
17             studentLog.UserTrueName = "123";
18             studentLog.UpdateDesc = "123";
19             studentLog.UpdateTime = DateTime.Now;
20             studentLog.UpdateTimeTag = DateTime.Now.Hour.ToString() +
21                                        DateTime.Now.Minute.ToString() +
22                                        DateTime.Now.Second.ToString() +
23                                        DateTime.Now.Millisecond.ToString();
24             this.db.StudentLogs.AddObject(studentLog);
25             this.db.SaveChanges();
26         }
保存记录到数据库

这样下来,通过调用一个保存编辑函数SaveStudentLog(行ID,修改前的值,修改后的值,列名)即可将修改的值信息保存到记录表里。

目录
相关文章
|
2月前
|
开发框架 .NET C#
C#|.net core 基础 - 删除字符串最后一个字符的七大类N种实现方式
【10月更文挑战第9天】在 C#/.NET Core 中,有多种方法可以删除字符串的最后一个字符,包括使用 `Substring` 方法、`Remove` 方法、`ToCharArray` 与 `Array.Copy`、`StringBuilder`、正则表达式、循环遍历字符数组以及使用 LINQ 的 `SkipLast` 方法。
|
3天前
|
程序员 C# 数据库
C# 比较对象新思路,利用反射技术打造更灵活的比较工具
中途接手的项目,碰到需要在更新对象信息时比较并记录差异的需求,最变态的还有附加要求,怎么办?有没有既能满足需求又能对项目影响最小的方法呢?分享这个我封装的方法,一个利用反射技术打造的更灵活的比较工具
|
2月前
|
编译器 C#
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
C#多态概述:通过继承实现的不同对象调用相同的方法,表现出不同的行为
130 65
|
1月前
|
JSON 程序员 C#
使用 C# 比较两个对象是否相等的7个方法总结
比较对象是编程中的一项基本技能,在实际业务中经常碰到,比如在ERP系统中,企业的信息非常重要,每一次更新,都需要比较记录更新前后企业的信息,直接比较通常只能告诉我们它们是否指向同一个内存地址,那我们应该怎么办呢?分享 7 个方法给你!
|
2月前
|
Java 程序员 C#
【类的应用】C#应用之派生类构造方法给基类构造方法传参赋值
【类的应用】C#应用之派生类构造方法给基类构造方法传参赋值
16 0
|
3月前
|
C# 数据安全/隐私保护
C# 一分钟浅谈:类与对象的概念理解
【9月更文挑战第2天】本文从零开始详细介绍了C#中的类与对象概念。类作为一种自定义数据类型,定义了对象的属性和方法;对象则是类的实例,拥有独立的状态。通过具体代码示例,如定义 `Person` 类及其实例化过程,帮助读者更好地理解和应用这两个核心概念。此外,还总结了常见的问题及解决方法,为编写高质量的面向对象程序奠定基础。
35 2
|
1月前
|
C# 开发者
C# 一分钟浅谈:Code Contracts 与契约编程
【10月更文挑战第26天】本文介绍了 C# 中的 Code Contracts,这是一个强大的工具,用于通过契约编程增强代码的健壮性和可维护性。文章从基本概念入手,详细讲解了前置条件、后置条件和对象不变量的使用方法,并通过具体代码示例进行了说明。同时,文章还探讨了常见的问题和易错点,如忘记启用静态检查、过度依赖契约和性能影响,并提供了相应的解决建议。希望读者能通过本文更好地理解和应用 Code Contracts。
41 3
|
9天前
|
存储 安全 编译器
学懂C#编程:属性(Property)的概念定义及使用详解
通过深入理解和使用C#的属性,可以编写更清晰、简洁和高效的代码,为开发高质量的应用程序奠定基础。
49 12
|
1月前
|
设计模式 C# 图形学
Unity 游戏引擎 C# 编程:一分钟浅谈
本文介绍了在 Unity 游戏开发中使用 C# 的基础知识和常见问题。从 `MonoBehavior` 类的基础用法,到变量和属性的管理,再到空引用异常、资源管理和性能优化等常见问题的解决方法。文章还探讨了单例模式、事件系统和数据持久化等高级话题,旨在帮助开发者避免常见错误,提升游戏开发效率。
59 4
|
3月前
|
API C#
C# 一分钟浅谈:文件系统编程
在软件开发中,文件系统操作至关重要。本文将带你快速掌握C#中文件系统编程的基础知识,涵盖基本概念、常见问题及解决方法。文章详细介绍了`System.IO`命名空间下的关键类库,并通过示例代码展示了路径处理、异常处理、并发访问等技巧,还提供了异步API和流压缩等高级技巧,帮助你写出更健壮的代码。
54 2