.net 利用Emit将object转为DbParameter,DataTable转为List<>
先放测试结果图,测试的方法是拷贝了老赵的一个简单的性能计数器:CodeTimer。发现速度还是比利用反射来获取快了2倍左右的,将object转为DbParameter的反射方法我没写。
在开发中,由于没有用第三方的orm框架,导致和数据库交互这里需要写很多的代码来拼接DbParameter。还有就是需要利用反射将DataTable转为List<>,在性能上会有点偏低。
所以我就花了几个礼拜时间看了下Emit,然后简单的实现了下一些自己常用的功能。大家如果觉得可以,可以直接下载代码拿去使用,如果发现哪里不对的或者有更好的实现方法的,欢迎指正与讨论。
使用说明:
//将Object转为paramList,SqlParameter是指DbParameter类型,三个参数,第一个参数是object,第二个参数是参数符号(@,:,?),第三个参数是前缀
var paramList = DbParamUtil.ToDbParam<SqlParameter>(new User(), "@", "w_");//
//将table转为对应List<T>, tableInstance是你需要转换的table,User是你要转换的实体类型
tableInstance.ToList<User>();
//将DataRow转为实体,dataRowInstance是你需要转换的DataRow,User是你要转换的实体类型
dataRowInstance.ToEntity<User>();
源码下载:
github地址:https://github.com/yjqGitHub/EmitConvert.git
后期如果有时间,且实现了ioc,也会在这个地址更新