·您现在的位置: 云翼网络 >> 文章中心 >> 网站建设 >> 网站建设开发 >> ASP.NET网站开发 >> Dapper小型ORM的使用(随便吐槽下公司)

Dapper小型ORM的使用(随便吐槽下公司)

作者:佚名      ASP.NET网站开发编辑:admin      更新时间:2022-07-23

Dapper小型ORM的使用(随便吐槽下公司)

  近来公司又有新项目要做,之前做项目用过蛮多ORM,包括ef,NetTiers,ServiceStack.OrmLite等ROM,每种ORM都有一定的坑(或者说是使用者的问题吧~~)。用来用去都觉的有一定的不爽。这次打算用Dapper这个ORM来做项目看看。首先感谢http://www.cnblogs.com/wywnet/p/33422150.html这位老兄给出的文章还有demo(建议大家可以看看),看了后深受启发。所以也确定用Dapper来练练手。好了,先介绍下Dapper这个ORM

1,Dapper是一个轻型的ORM类。代码就一个SqlMapper.cs文件,编译后就40K的一个很小的Dll. 小型ORM

2,Dapper很快。Dapper的速度接近与IDataReader,取列表的数据超过了DataTable。 速度快

3,Dapper支持什么数据库。Dapper支持MySQL,SqlLite,Mssql2000,Mssql2005,Oracle等一系列的数据库 支持多数据库

4,Dapper的r支持多表并联的对象。支持一对多 多对多的关系。并且没侵入性,想用就用,不想用就不用。无xml无属性。代码以前怎么写现在还怎么写。 灵活性高

5,Dapper原理通过Emit反射IDataReader的序列队列,来快速的得到和产生对象。性能实在高高高。性能高

6,Dapper支持net2.0,3.0,3.5,4.0。【如果想在Net2.0下使用,可以去网上找一下Net2.0下如何配置运行Net3.5即可。】 支持多个.net版本

7,Dapper语法十分简单。并且无须迁就数据库的设计。 语法简单,可扩展性强

Dapper官网:https://code.google.com/p/dapper-dot-net/

Dapper简单使用:http://www.cnblogs.com/wywnet/p/3422150.html

SqlMapper.cs 是最基础的底层文件,为了更好的运用,先对Dapper进行扩展,这里写一个Dapper的扩展类(这里只列出主要的类,一些辅助类就不列出了)

Dapper扩展类,DapperEx.cs

  1    public static class DapperEx  2     {  3   4   5         /// <summary>  6         /// 插入数据  7         /// </summary>  8         /// <typeparam name="T"></typeparam>  9         /// <param name="dbs"></param> 10         /// <param name="t"></param> 11         /// <param name="transaction"></param> 12         /// <param name="commandTimeout"></param> 13         /// <returns></returns> 14         public static int Insert<T>(this DbBase dbs, T t, IDbTransaction transaction = null, int? commandTimeout = null) where T : class 15         { 16             var db = dbs.DbConnecttion; 17             var sql = SqlQuery<T>.Builder(dbs); 18             var flag = db.Execute(sql.InsertSql, t, transaction, commandTimeout); 19             int KeyID = 0; 20             SetIdentity(db, (id) => { KeyID = id; }, transaction); 21             return KeyID; 22             //return flag == 1; 23         } 24  25         /// <summary> 26         ///  批量插入数据 27         /// </summary> 28         /// <typeparam name="T"></typeparam> 29         /// <param name="dbs"></param> 30         /// <param name="lt"></param> 31         /// <param name="transaction"></param> 32         /// <param name="commandTimeout"></param> 33         /// <returns></returns> 34         public static bool InsertBatch<T>(this DbBase dbs, IList<T> lt, IDbTransaction transaction = null, int? commandTimeout = null) where T : class 35         { 36             var db = dbs.DbConnecttion; 37             var sql = SqlQuery<T>.Builder(dbs); 38             var flag = db.Execute(sql.InsertSql, lt, transaction, commandTimeout); 39             return flag == lt.Count; 40         } 41  42         /// <summary> 43         /// 按条件删除 44         /// </summary> 45         /// <typeparam name="T"></typeparam> 46         /// <param name="dbs"></param> 47         /// <param name="sql"></param> 48         /// <returns></returns> 49         public static bool Delete<T>(this DbBase dbs, SqlQuery sql = null, IDbTransaction transaction = null) where T : class 50         { 51             var db = dbs.DbConnecttion; 52             if (sql == null) 53             { 54                 sql = SqlQuery<T>.Builder(dbs); 55             } 56             var f = db.Execute(sql.DeleteSql, sql.Param, transaction); 57             return f > 0; 58         } 59  60         /// <summary> 61         /// 按指定某型删除 62         /// </summary> 63         /// <typeparam name="T"></typeparam> 64         /// <param name="dbs"></param> 65         /// <param name="sql">如果sql为null,则根据t的主键进行修改</param> 66         /// <returns></returns> 67         public static bool Delete<T>(this DbBase dbs, T t, IDbTransaction transaction = null) where T : class 68         { 69             var db = dbs.DbConnecttion; 70             SqlQuery sql = SqlQuery<T>.Builder(dbs); 71             sql = sql.AppendParam<T>(t); 72             var f = db.Execute(sql.DeleteSql, sql.Param, transaction); 73             return f > 0; 74         } 75  76         /// <summary> 77         /// 指定主键ID删除数据 78         /// </summary> 79         /// <typeparam name="T"></typeparam> 80         /// <param name="dbs"></param> 81         /// <param name="ID"></param> 82         /// <param name="transaction"></param> 83         /// <returns></returns> 84         public static bool DeleteByID<T>(this DbBase dbs, object ID, IDbTransaction transaction = null) where T : class 85         { 86             var db = dbs.DbConnecttion; 87             SqlQuery sql = SqlQuery<T>.Builder(dbs); 88             sql.KeyValue = ID; 89             var f = db.Execute(sql.DeleteKeySql, sql.Param, transaction); 90             return f > 0; 91         } 92  93         /// <summary> 94         /// 修改 95         /// </summary> 96         /// <typeparam name="T"></typeparam> 97         /// <param name="dbs"></param> 98         /// <param name="t">如果sql为null,则根据t的主键进行修改</param> 99         /// <param name="sql">按条件修改</param>100         /// <returns></returns>101         public static bool Update<T>(this DbBase dbs, T t, SqlQuery sql = null, IDbTransaction transaction = null) where T : class102         {103             var db = dbs.DbConnecttion;104             if (sql == null)105             {106                 sql = SqlQuery<T>.Builder(dbs);107             }108             sql = sql.AppendParam<T>(t);109             var f = db.Execute(sql.UpdateSql, sql.Param, transaction);110             return f > 0;111         }112 113         /// <summary>114         /// 修改115         /// </summary>116         /// <typeparam name="T"></typeparam>117         /// <param name="dbs"></param>118         /// <param name="t">如果sql为null,则根据t的主键进行修改</param>119         /// <param name="updatePRoperties">要修改的属性集合</param>120         /// <param name="sql">按条件修改</param>121         /// <returns></returns>122         public static bool Update<T>(this DbBase dbs, T t, IList<string> updateProperties, SqlQuery sql = null, IDbTransaction transaction = null) where T : class123         {124             var db = dbs.DbConnecttion;125             if (sql == null)126             {127                 sql = SqlQuery<T>.Builder(dbs);128             }129             sql = sql.AppendParam<T>(t)130                 .SetExcProperties<T>(updateProperties);131             var f = db.Execute(sql.UpdateSql, sql.Param, transaction);132             return f > 0;133         }13