c# DataTable、IReader与List<T>互转 emit方法

网上有很多ORM框架和数据库转换方法。

c#由EF控制,但是大家知道的是影响效率和底层控制。

因此最近几个月一直在研究。最后使用Emit实现了转换。

  最新增加了(修复)对实体的可空类型的支持。

需要说明的是,以前我被骗了,没有怎么研究过,只是会使用可空类型,但是为了实现转换,支持可空类型,在研究emit是才知道,给可空类型赋值实际是有一个转换的。例如:

  int? a=4;

该语句实际是Nullable<int> a=new Nullable<int>();所以是有一个初始化的过程和分配过程,也许比类要好点。

但是在执行emit时发现还是会影响性能速度,虽然很小,几乎不会知道。因此在与数据库转换时,尤其是你需要高速转换时,不要使用可空类型。

使用说明:

1.采用emit方法DataTable,IDataReader与实体相互转换。

2.DataTable,IDataReader转换实体: ToEntityList扩展方法

3.实体转换DataTable: FromEntityToTable扩展方法

4.如果实体转换DataTable带有特性: FromEntityToTableAttribute扩展方法

设计了三类特性ColumnType(列类型映射),DataField(列名称映射),NoColumn(没有对应的列,忽略该属性。


DataTable dt = new DataTable();
dt.Columns.Add("Id", typeof(int));
dt.Columns.Add("DTO", typeof(string));
dt.Rows.Add(1, "3e-6");
dt.Rows.Add(2, "5000");

      List<Person> lst=  dt.ToEntityList<Person>(); //转model  

      DataTable dd=  lst.FromEntityToTable();//转回DataTable  

IDataReader idr = null;
List lstm= idr.ToEntityList(); //转model DataTable dds= lstm.FromEntityToTableAttribute(); //转回DataTable 定义:
public class Person
{
public int Id { get; set; }

    [ColumnType(typeof(double))]  
    public decimal? DTO { get; set; }  

    [DataField("user")]  
    public string Name { get; set; }  
}  

如果程序报错:没有找到列,则说明你使用了不同的数据转model,但是这些数据不一样。这时你可以使用重载方法,定一个唯一key

项目地址:

https://github.com/jinyuttt/EntityMappingDBEmit.git

已经提交nuget,名称:EntityMappingDB

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值