亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

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

2019-11-17 02:00:23
字體:
來源:轉載
供稿:網友

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

  近來公司又有新項目要做,之前做項目用過蠻多ORM,包括ef,NetTiers,ServiceStack.OrmLite等ROM,每種ORM都有一定的坑(或者說是使用者的問題吧~~)。用來用去都覺的有一定的不爽。這次打算用Dapper這個ORM來做項目看看。首先感謝http://www.49028c.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.49028c.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
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩中文字幕在线精品| 免费av在线一区| 国产在线精品自拍| 日韩精品在线私人| 美女啪啪无遮挡免费久久网站| 色偷偷91综合久久噜噜| 日韩午夜在线视频| 中文字幕最新精品| 不卡av电影在线观看| 日韩av大片在线| 亚洲激情国产精品| 国产精品视频永久免费播放| 亚洲国产一区二区三区四区| 亚洲一区二区久久久久久| 91成人在线视频| 欧美中文字幕视频在线观看| 久久久天堂国产精品女人| 日韩精品高清视频| 欧美日韩亚洲精品一区二区三区| 日韩中文字幕视频在线| 日韩av中文字幕在线| 91精品国产自产在线| 久久夜色撩人精品| 久久久久久亚洲| 中文字幕日韩精品在线| 92版电视剧仙鹤神针在线观看| 中文字幕精品一区久久久久| 久久久成人av| 国产一区红桃视频| 成人黄色影片在线| 亚洲欧美中文日韩在线v日本| 一本大道香蕉久在线播放29| 欧美日韩午夜剧场| 日韩美女av在线| 久久在线免费视频| 欧美天堂在线观看| 亚洲国产精品va在线观看黑人| 日韩av一区二区在线| 欧美老女人在线视频| 久热精品视频在线| 国产精品亚洲аv天堂网| 不卡av电影在线观看| 欧美日韩国产精品一区| 国产69精品久久久久久| 亚洲欧洲黄色网| 日韩免费黄色av| 777午夜精品福利在线观看| 91久久精品国产91久久性色| 最近2019免费中文字幕视频三| 亚洲人成电影在线播放| 日韩av最新在线观看| 欧美电影免费观看网站| 亚洲国产精品成人一区二区| 中文字幕亚洲欧美日韩在线不卡| 亚洲欧美日韩综合| 欧美亚洲在线播放| 亚洲品质视频自拍网| 国产精品香蕉在线观看| 国内偷自视频区视频综合| 最近2019中文字幕在线高清| 亚洲欧洲视频在线| 国产精品一区二区电影| 91国语精品自产拍在线观看性色| 青草热久免费精品视频| 日韩av最新在线| 亚洲国产精品一区二区久| 亚洲高清av在线| 亚洲永久免费观看| 国产精品久久久久久久久久小说| 欧美激情中文字幕乱码免费| 欧美激情a在线| 爱福利视频一区| 中文字幕亚洲第一| 久久99久久亚洲国产| 国产丝袜一区视频在线观看| 日韩中文在线中文网在线观看| 亚洲精品久久久久久下一站| 国产女同一区二区| 成人精品在线视频| 国模精品一区二区三区色天香| 日韩精品中文字幕有码专区| 91青草视频久久| 国产一区二区丝袜高跟鞋图片| 欧美综合激情网| 成人欧美一区二区三区黑人孕妇| 欧美激情精品久久久久久| 国产精品中文在线| 亚洲色图13p| 最近日韩中文字幕中文| 亲爱的老师9免费观看全集电视剧| 国产精品入口夜色视频大尺度| 国产亚洲视频在线| 97视频人免费观看| 亚洲高清一区二| 欧美日韩国产中文精品字幕自在自线| 欧美高清在线观看| 亚洲xxxx3d| 一区二区三区无码高清视频| 国产视频一区在线| 国产精品伦子伦免费视频| 视频一区视频二区国产精品| 日韩男女性生活视频| 免费97视频在线精品国自产拍| 国产精品亚洲欧美导航| 国产精品入口福利| 在线观看国产精品淫| 日韩美女中文字幕| 日韩成人中文电影| 亚洲欧美一区二区精品久久久| 91高潮精品免费porn| 成人伊人精品色xxxx视频| 亚洲97在线观看| 亚洲人午夜色婷婷| 亚洲开心激情网| 亚洲天堂影视av| 国产91在线视频| 97精品在线观看| 亚洲电影免费观看高清| 亚洲一区二区久久久| 2019av中文字幕| 国产福利视频一区| 欧美性少妇18aaaa视频| 亚洲精品国偷自产在线99热| 91九色国产社区在线观看| 亚洲欧美国内爽妇网| 欧美极品少妇xxxxx| 久久九九亚洲综合| 精品视频在线导航| 国产一区二区激情| 性亚洲最疯狂xxxx高清| 日本欧美在线视频| 久久天天躁狠狠躁老女人| 欧美色播在线播放| 国产日韩亚洲欧美| 91精品中国老女人| 欧美一级片免费在线| 国产精品美女999| 97在线看免费观看视频在线观看| 亚洲自拍中文字幕| 456亚洲影院| 亚洲一区制服诱惑| 久久天天躁狠狠躁夜夜躁2014| 中文字幕日韩欧美在线视频| 国产va免费精品高清在线观看| 国产中文字幕亚洲| 18一19gay欧美视频网站| 国产精品一区二区女厕厕| 欧美极品少妇xxxxⅹ喷水| 国产亚洲美女久久| 久久久精品免费| 亚洲女人被黑人巨大进入al| 欧美激情手机在线视频| 国产精品激情av电影在线观看| 亚洲成人网久久久| 亚洲国产小视频| 在线成人激情视频| 欧美成人午夜视频| www.亚洲天堂| 色777狠狠综合秋免鲁丝| 亚洲激情自拍图| 中文字幕国产亚洲2019| 久久久久久久成人| 国产精品视频yy9099| 大荫蒂欧美视频另类xxxx|