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的话,大可没必要点窜