近來公司又有新項目要做,之前做項目用過蠻多ORM,包括ef,NetTiers,ServiceStack.OrmLite等ROM,每種ORM都有一定的坑(或者說是使用者的問題吧~~)。用來用去都覺的有一定的不爽。這次打算用Dapper這個ORM來做項目看看。首先感謝http://www.companysz.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?!救绻朐贜et2.0下使用,可以去網上找一下Net2.0下如何配置運行Net3.5即可?!?支持多個.net版本
7,Dapper語法十分簡單。并且無須遷就數據庫的設計。 語法簡單,可擴展性強
Dapper官網:https://code.google.com/p/dapper-dot-net/
Dapper簡單使用:http://www.companysz.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="update
新聞熱點
疑難解答