麓谷官网欢迎你访问长沙北大青鸟麓谷校区,支持你成为一个受人尊重的专业人才!
当前位置: 首页 > 青鸟知识 > net

orm东西Dapper在大都据库方面的优化

来源:长沙北大青鸟新途|发布时间:2016-05-21|浏览量:

学IT,好工作

就读长沙岳麓职业培训学校

求学热线: 400-160-2868

Dapper是近2年异军崛起的新ORM东西,它有ado.net般的高机能又有反射映照实体的矫捷性,很是适宜爱好原生sql的法式员应用,并且它源码很小,特别烦琐。我写本博客的目的不是为了先容Dapper,而是要将我应用Dapper迁移数据库进程中碰到的bug和一些优化先容给巨匠,Dapper在大都据库支撑上有些标题,我做了以下5个方面的优化。


一:Dapper焦点库存在一个主要的bug是各数据库默许前往类型分歧酿成的,像count,sum等一些函数在分歧的数据库前往类型分歧。好比 select count(1) from Table;  sqlserver前往值类型是int,oracle是decimal,mysql是long。那末

connection.Query int ( select count(*) from Table

这条语句运转在sqlserver下没标题,其他数据库会由于类型不婚配报错。一样的,Dapper要务实体对象的类型必需残酷的与数据库类型逐一对应(首要是呈如今int,byte和enum类型上)。处置的法子是将强迫转换类型改成通用转换,把Dapper代码中的这句return val is DBNull ? null : val;

改成:return val is DBNull ? null : Convert.ChangeType(val, type);


二:没有供应参数前缀转换的功用,这点能够在SetupCommand方式中自行写方式替代。


三:Dapper只供应最根基的orm框架,对增删改没有供应简约的方式,Dapper扩展类就是供应这类功用的,但此扩展类存在一个缺乏:增改时会将实体一切字段都拼接到sql中,没法只增改部门字段,把nullable类型的字段当作浅显字段处置。这里我中止了优化:拼接sql时断定字段的值是不是为空,为空的字段不做处置。


四:官方的Dapper扩展类参数前缀用的是 @ ,这不适宜规范,改成经由过程

IDbConnection类型断定加前缀。


五:添加各数据库通用分页方式及TOP方式。

做这么多优化目的只需一个:能够或许无缝的迁移数据库。若是你一向就用sqlserver的话,大可没必要点窜


上一篇:返回列表

下一篇:.Net中的反射

扫码关注微信公众号了解更多详情

跟技术大咖,专业导师一起交流学习

姓名
电话
Q Q

在线留言

请您把问题留下,我们为您提供专业化的解答!

QQ咨询
  1. 招生问答
  2. 热门点击
  3. 最新更新
  4. 推荐文章

关于我们

学校成就

就业保障

联系方式

联系电话:400-160-2868

在线报名

预约报名

备案号:湘ICP备2020021619号-1
地址:湖南省长沙市高新区麓谷麓松路679号 版权所有:长沙市岳麓职业培训学校

在线咨询
课程咨询 学费咨询 学费分期 入学测试 免费预约 来校路线
初中生 高中生 待业者
400-160-2868

在线客服