技术图文:如何实现 DataTable 与模型类 List 的相互转换?
通常情况下,我们在做工程项目的时候,需要把待处理的数据存储在数据库中。
通过 SQL
的 Select
语句很容易把查询的结果以 DataTable
的方式得到,但在对 DateTable
中的数据进行进一步的检索时远远没有模型类 List<T>
方便。 所以,在做工程项目时,会把查询到的 DataTable
转化成模型类 List<T>
, 处理完毕后如果有所改动则把这个模型类 换回成 DataTable
以便完成数据库中的相应改动。
上周在做一个电力局项目时对导入的上万条数据进行插入操作就是这样做的,参见一下图文:
- 如何利用 C# 向 Access 数据库插入大量数据?
技术分析
如何实现 DataTable
与 List<T>
的相互转化呢?
这里需要掌握 C# 中的 泛型 以及 反射 的基础知识。
泛型部分:
- 泛型(一):泛型概述
- 泛型(二):泛型的优点
- 泛型(三):泛型之类型参数
- 泛型(四):泛型之类型参数约束
- 泛型(五):泛型类
- 泛型(六):泛型接口
- 泛型(七):泛型方法
- 泛型(八):泛型委托
- 泛型(九):泛型代码中的default关键字
反射部分:
- 反射技术(一):前期准备
- 反射技术(二):窥视内部
- 反射技术(三):深入窥视字段
- 反射技术(四):深入窥视属性
- 反射技术(五):深入窥视方法
- 反射技术(六):深入窥视DLL内部
- 反射技术(七):通过反射实例化对象
通过泛型,我们可以把任何一个模型类 List<T>
转化成 DataTable
,也可以把任何一个 DataTable
转化成对应的 List<T>
,只要这里 T
类型的 public 属性 与 DataTable
的 ColumnName
对应即可。当然属性的获取是通过反射技术完成的。
有关泛型和反射的知识,可以查看上面的图文,我在这里就不在重复了。
代码实现
下面,通过一个实际项目的例子来说明相互转换的代码与具体的应用。
Step1. 设备台账的结构 AcountItem
。
/// <summary>
/// 台账Item
/// </summary>
public class AccountItem
{/// <summary>/// 设备ID/// </summary>public string EquipmentId{get;set; }/// <summary>/// 厂站名称/// </summary>public string FactoryStationName{get;set; }/// <summary>/// 厂站类型/// </summary>public string FactoryStationType{get;set; }/// <summary>/// 一次设备名称/// </summary>public string PrimaryDeviceName { get; set; }/// <summary>/// 一次设备电压等级/// </summary>public string PrimaryDeviceVoltageLevel { get; set; }/// <summary>/// 制造厂家/// </summary>public string Manufacturer { get;set; }/// <summary>/// 保护类别/// </summary>public string ProtectionCategory {get;set; }/// <summary>/// 保护型号/// </summary>public string ProtectionType {get;set; }/// <summary>/// 软件版本/// </summary>public string SoftwareVersion { get;set; }/// <summary>/// 保护名称/// </summary>public string ProtectionName {get;set; }/// <summary>/// 投运日期/// </summary>public string CommissionDate {get;set; }/// <summary>/// 出厂日期/// </summary>public string ProductionDate {get;set; }/// <summary>/// 所在屏柜/// </summary>public string ScreenCabinets {get;set; }/// <summary>/// 保护套别/// </summary>public string ProtectiveSleeve {get;set; }
}
Step2. 把模型类 List<T>
转化为 DataTable
。
public static DataTable ListToDataTable<T>(IEnumerable<T> collection)
{if (collection == null)throw new ArgumentNullException();PropertyInfo[] props = typeof (T).GetProperties();DataTable dt = new DataTable();dt.Columns.AddRange(props.Select(p => new DataColumn(p.Name, p.PropertyType)).ToArray());if (collection.Any()){for (int i = 0; i < collection.Count(); i++){ArrayList tempList = new ArrayList();foreach (PropertyInfo pi in props){object obj = pi.GetValue(collection.ElementAt(i), null);tempList.Add(obj);}object[] array = tempList.ToArray();dt.LoadDataRow(array, true);}}return dt;
}
Step3. 举例,把 List<AcountItem>
转化为 DataTable
。
// 初始化链表并加入数据。
List<AccountItem> lst = new List<AccountItem>(); DataTable dt = ListToDataTable(lst);
dt
数据表列集合的列名依次为:
- EquipmentId
- FactoryStationName
- FactoryStationType
- PrimaryDeviceName
- PrimaryDeviceVoltageLevel
- Manufacturer
- ProtectionCategory
- ProtectionType
- SoftwareVersion
- ProtectionName
- CommissionDate
- ProductionDate
- ScreenCabinets
- ProtectiveSleeve;
Step4. DataTable 转化为 List。
public static List<T> DataTableToList<T>(DataTable dt) where T : new()
{List<T> result = new List<T>();foreach (DataRow dr in dt.Rows){T item = new T();PropertyInfo[] props = item.GetType().GetProperties();foreach (PropertyInfo pi in props){string tempName = pi.Name;if (dt.Columns.Contains(tempName)){if (pi.CanWrite == false)continue;object value = dr[tempName];if (value != DBNull.Value)pi.SetValue(item, value, null);}}result.Add(item);}return result;
}
Step5. 举例,把 Step3 得到的 DataTable
转化为 List<AccountItem>
。
List<AccountItem> lst = DataTableToList(dt);
通过调用 Step4 带约束的泛型方法,可以得到模型类 List<AccountItem>
。
总结
到此为止,DataTable
与 List<T>
的相互转换就介绍完了,由于整个项目都是利用 List<T>
来构建逻辑的,所以整个系统可以具有良好的结构,通过 LINQ 也能满足效率的要求。今天就到这里吧!See You!
相关图文:
- 如何利用 C# 实现 K 最邻近算法?
- 如何利用 C# 实现 K-D Tree 结构?
- 如何利用 C# + KDTree 实现 K 最邻近算法?
- 如何利用 C# 对神经网络模型进行抽象?
- 如何利用 C# 实现神经网络的感知器模型?
- 如何利用 C# 实现 Delta 学习规则?
- 如何利用 C# 开发「桌面版百度翻译」软件!
- 如何利用 C# 开发「股票数据分析软件」(上)
- 如何利用 C# 开发「股票数据分析软件」(中)
- 如何利用 C# 开发「股票数据分析软件」(下)
- 如何利用 C# 爬取「财报说」中的股票数据?
- 如何利用 C# 爬取 One 持有者返利数据!
- 如何利用 C# 爬取Gate.io交易所的公告!
- 如何利用 C# 爬取BigOne交易所的公告!
- 如何利用 C# 爬取 ONE 的交易数据?
- 如何利用 C# 爬取「京东 - 计算机与互联网图书销量榜」!
- 如何利用 C# 爬取「当当 - 计算机与互联网图书销量榜」!
- 如何利用 C# 爬取「互动出版网 - 计算机图书销量榜」!
- 如何利用 C# 爬取「中国图书网 - 计算机与互联网图书销量榜」!
- 如何利用 C# 爬取「猫眼电影:热映口碑榜」及对应影片信息!
- 如何利用 C# 爬取「猫眼电影专业版:票房」数据!
- 如何利用 C# 爬取「猫眼电影:最受期待榜」及对应影片信息!
- 如何利用 C# 爬取「猫眼电影:国内票房榜」及对应影片信息!
- 如何利用 C# + Python 破解猫眼电影的反爬虫机制?
- 如何利用 C# 爬取带 Token 验证的网站数据?
相关文章:

SQL server 基本语句
SQL server数据库基本语句一、实验要求:1、 查询student表中所有学生的信息select * from student如图所示2、查询student表中“姓名”“所在班级”和“成绩”列内容select 姓名,所在班级,成绩 from student如图所示3、查询student表…

Python中if条件判断语句怎么用?
俗话说“不积跬步无以至千里”。学习了Python的基本语法后,接下来我们学习Python常的if条件判断语句。 if语句是最简单的条件判断语句,它可以控制程序的执行流程,其使用格式如下: if判断条件: 满足条件时要做的事情1… 满足条件时要做的事情2…

Arcmap技巧总结
Arcmap技巧总结 1. 要素的剪切与延伸 实用工具 TASK 任务栏 Extend/Trim feature 剪切所得内容与你画线的方向有关。 2. 自动捕捉跟踪工具 点击Editor工具栏中Snapping来打开Snapping Environment对话框 捕捉设置中有3个选项, vertex edge end 分…
Spring Web MVC(一)
概述Spring Web MVC框架的特点五大核心组件编程步骤 五大核心组件DispatcherServlet前端控制器WebApplicationContext中特殊的bean处理过程 HandlerMapping 处理映射Spring中最常用的两个处理器映射BeanNameUrlHandlerMappingSimpleUrlHandlerMapping拦截器HandlerInterceptor概…

技术图文:如何利用BigOne的API制作自动化交易系统 -- 身份验证
背景 最近,自己在技术精进方向上有所犹豫,是往"网络渗透"的方向走呢?还是往"量化交易"的方向走? 如果选择精进“网络渗透”,就需要学习各种Web渗透技术、客户端渗透技术、移动环境渗透技术、社会…

零基础学习java软件开发攻略
Java是主流开发语言,应用普遍。Spring Boot是Java开发时常用框架,有非常丰富的组件和易用的功能。实际开发工作中涉及到的知识点比较多,将它们分门别类,专题攻关,由点到面,学习效率非常高。 软件开发系统学…

Linux--档案/目录 权限及修改
首先所有权限对于三类用户分别设定: User(所有者) / Group(组群) / Others(其他)。 权限也是有三种:Read / Write / eXecute,这三种权限对于文档和目录有不同的意义。 1. 对于文档: Read:可以查看文档的内容 Write&…
sklearn:Python语言开发的通用机器学习库
引言:深入理解机器学习并全然看懂sklearn文档,须要较深厚的理论基础。可是。要将sklearn应用于实际的项目中,仅仅须要对机器学习理论有一个主要的掌握,就能够直接调用其API来完毕各种机器学习问题。本文选自《全栈数据之门》。将向…

资料分享:送你一本《BigONE Developer API V2》电子书!
背景 昨天,我推送了一篇技术图文《如何利用 BigOne 的 API 制作自动化交易系统 – 身份验证》,里面提到了 BigONE Developer API V2。为了方便自己也方便他人,所以把这份文档整理成 PDF。如果大家对封装 BigONE 提供的 API 感兴趣可以下载这…

Web前端培训面试攻略
学会web前端技术之后,接下来就是要找到一份合适的工作,今天小编要跟大家分享的文章是关于web前端面试攻略,做好这些可以给面试环节加分,找到合适的工作几率会更高,希望本篇文章能够对大家有所帮助。 Web前端培训…

微软鲍尔默回应被苹果超越:将开发更好产品
针对苹果超过微软成为全球市值最高的高科技公司的消息,微软首席执行官史蒂夫鲍尔默 (Steve Ballmer)周四表示,其目标是开发更好的产品,提高盈利能力。鲍尔默周四在印度首都新德里说,“我每天思考的是如何改进产品、如何使产品更 具…

技术图文:如何利用C#实现Huffman编码?
背景 Huffman编码 在通信和数据压缩领域具有重要的应用。 在介绍 Huffman 编码具体实现之前,先介绍几个相关的概念。 概念1:树中结点的带权路径长度 – 根结点到该结点的路径长度与该结点权值的乘积。 概念2:树的带权路径长度 – 树中所有…

ELK 5.x日志分析 (二) Elasticserach 5.2 安装
2019独角兽企业重金招聘Python工程师标准>>> 解压安装包到/opt/elasticsearch 目录下面 [roots1-prod-it-web01 opt]# tree -L 1 elasticsearch/ elasticsearch/ ├── bin ├── config ├── lib ├── LICENSE.txt ├── modules ├── NOTICE.txt ├── …

什么样的人适合学习UI?
UI时代的到来,让我们的生活都多姿多彩,很多企业越来越注重UI设计这方面,想要学习UI设计的人也越来越多,暗恶魔什么样的人适合学习UI呢? 什么样的人适合学习UI? 目前的UI设计很多都是停留在手机端设计,网页࿰…

Uva 10074【递推dp】
UVa 10074 题意:求01矩阵的最大子0矩阵。 http://www.csie.ntnu.edu.tw/~u91029/MaximumSubarray.html#2 这里说的很清楚。先求Largest Empty Interval,枚举每个点为矩形的右下角。 1 #include<iostream>2 #include<cstdio>3 #include<cstring>4 #include<…

金融时报:谷歌撤离中国有99.9%的可能性
据国外媒体报道,英国《金融时报》周六发表文章称,谷歌与中国政府就监管问题的谈判显然陷入僵局,而这家世界最大的搜索引擎关闭中国业务现在有99.9%的可能性。《金融时报》称,谷歌已经制定了关闭中国搜索引擎的详细计划。该报援引一…

技术图文:匿名方法是怎样演变为Lambda表达试的?
背景 “Lambda 表达式”(lambda expression)是一个匿名函数,Lambda 表达式基于数学中的 λ演算得名,直接对应于其中的 lambda 抽象(lambda abstraction),是一个匿名函数,即没有函数…

python和c++的相互调用教程
日常工作中会遇到需要python与cpp代码之间的相互调用,工作的应用复杂,都是取决于代码的多少,但是总的方法不变,这里用两个简单例子说明下,有兴趣的筒子可以探讨下~~ 我的测试环境:ubuntu1604,py…

技术图文:如何通过 LINQ 查找集合中的重复数据?
背景 在前几天介绍的 如何利用C#实现Huffman编码? 的图文中有以下代码。 private List<HuffmanTreeNode> CreateInitForest(string str) {if (string.IsNullOrEmpty(str))throw new ArgumentNullException();List<HuffmanTreeNode> result new List&…

mysql的基本知识
安装:http://www.cnblogs.com/sshoub/p/4321640.html 导库 http://www.cnblogs.com/yuwensong/p/3955834.html 报错:Error was: No module named PIL pip install image转载于:https://www.cnblogs.com/baldermurphy/p/7403778.html

msys下产生dll的导入库
有些时候在只有一个dll的情况下,如果需要隐式链接的话,就需要为该dll产生一个导入库.注意导入库是不能跨编译器使用的,在mingw中导入库需要以.a结尾,而vs则以.lib 以下的方法是在Msys产生mingw及vs 的导入库 , 打开MSys工具 首先生成dll库的d…

零基础小白如何学习好UI设计
智能时代的来临,很多企业都越来越注重用户体验这一块,想要有一个吸引用户的好页面,UI设计师岗位不可或缺,如今越来越多的人想要学习UI设计技术,那么对于零基础小白如何学习好UI设计呢? 零基础小白如何学习好UI设计? …

技术图文:如何利用BigOne的API制作自动化交易系统 -- 获取账户资产
背景 前几天我们介绍了如何使用 BigONE Developer API V2 来获取身份令牌的方法「如何利用BigOne的API制作自动化交易系统 – 身份验证」。一旦获取了身份令牌,我们就可以在网络请求的 header 中加入令牌来获取自己的账户数据,创建买入、卖出订单&#…

『网站升级』PHPWind8.0至8.3升级过程及问题种种回顾录
上星期的PHPWind杭州峰会之后,PHPWind发布了8.3版。紧接着淘连接,淘满意,团购PHPWind的一系统ARP应用开始进入我们公司技术苦力的耳朵里(也就是偶),偶知道有大事要发生了。于是乎。领导悠然降至,…

新浪 抓取详情页
转载于:https://www.cnblogs.com/tian-sun/p/7404493.html

零基础如何学习软件测试
很多人想学软件测试是因为软件测试是进入到IT行业里比较快的一门技术,软件测试的门槛比较低,初学者和零基础小白学起来都是比较容易的,下面小编就详细的给大家介绍一下具体零基础如何学习软件测试? 零基础如何学习软件测试?对于初级测试而言…
VPS使用初体验
很早就想建个人网站,但是出于各种限制,一直没有实施。前几天开通了网银,便再次萌发了建站的想法。。。 购买一个了enom的域名,然后寻找比较好的虚拟主机,发现ubuntuchina上有个卖vps的,价格还行,…

LeetCode实战:相同的树
题目英文 Given two binary trees, write a function to check if they are the same or not. Two binary trees are considered the same if they are structurally identical and the nodes have the same value. Example 1: Input: 1 1/ \ / \2 3 …

mysql数据库常用命令
登录: mysql -h 服务器地址 -u 登录名 -P 端口 -p 密码 (登录时最好先不输入密码,等下一条提示出来之后再输,这样可以在界面中隐藏密码) 退出: quit 或者 exit 注意:登录数据库系统后࿰…

Java入门学习注意事项有哪些?
想要学好java技术,做好学习规划路线和注意事项是非常重要的,尤其是零基础学员,Java涉及到的知识点非常多,我们需要制定合理的Java学习路线图,这样会事半功倍,下面小编和大家总结一下Java入门学习注意事项有…