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

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

微型ORM的第二篇DapperLambda性能測試[Dapper比較篇]

2019-11-14 13:34:59
字體:
來源:轉載
供稿:網友

由于這周比較忙,所以本來想做的性能測試,一直沒時間,想想還是今天給補上吧

由于很多人都擔心性能問題,封裝之后跟Dapper的性能差距是多少,今天我給出我的測試方法,僅供參考.

  1. 創建IDbConnection;(DapperLambda 已經把IDbConnection封裝在DbContext,所以創建的是DbContext)
 1   public class DBHelper 2     { 3         PRivate static string localStr = "server=(local);User ID=sa;PassWord=password01!;Database=LocalDB;Persist Security Info=True;Pooling=true;Max Pool Size=700"; 4         public static DbContext GetContext() 5         { 6             return new DbContext().ConnectionString(localStr); 7         } 8         public static System.Data.IDbConnection GetDapperConnection() 9         {10             return new System.Data.SqlClient.SqlConnection(localStr);11         }12     }

 

   2.主要針對幾個增刪改查,幾個做比較,但是用到Dapper比較簡單,都是執行SQL+參數。。

    1).查詢語句的比較

       public static long DapperSelect()        {            Stopwatch timer = new Stopwatch();            timer.Start();            Random r = new Random();            using (var conn = DBHelper.GetDapperConnection())            {                var item = conn.Query<Models.MobileForTest>("SELECT * FROM MobileForTest mft WHERE mft.ID=@ID", new { ID = r.Next(1, 3014) });            }            timer.Stop();            return timer.ElapsedMilliseconds;        }       public static long DapperLambdaSQLSelect()        {            Stopwatch timer = new Stopwatch();            timer.Start();            Random r = new Random();            using (var context = DBHelper.GetContext())            {                var item = context.Sql("SELECT * FROM MobileForTest mft WHERE mft.ID=@ID", new { ID = r.Next(1, 3014) }).QueryMany<MobileForTest>();            }            timer.Stop();            return timer.ElapsedMilliseconds;        }        public static long DapperLambdaSelectByID()        {            Stopwatch timer = new Stopwatch();            timer.Start();            Random r = new Random();            using (var context = DBHelper.GetContext())            {                var item = context.Select<MobileForTest>(r.Next(1, 3014));            }            timer.Stop();            return timer.ElapsedMilliseconds;        }        public static long DapperLambdaSelectByLambda()        {            Stopwatch timer = new Stopwatch();            timer.Start();            Random r = new Random();            using (var context = DBHelper.GetContext())            {                var item = context.Select<MobileForTest>(p => p.ID == r.Next(1, 3014)).QueryMany();            }            timer.Stop();            return timer.ElapsedMilliseconds;        }

 

原本計劃是起四個線程,在各自線程里調用相應的方法500次,取總耗時時間,發現線程啟動的順序,對測試的結果有明顯的影響。因此改成同步的調用每個方法500次,取平均時長。測試結果如下如。

跟預期差不多是一致。

2.單條數據插入的

        public static long DapperSQLInsert()        {            Stopwatch timer = new Stopwatch();            timer.Start();            using (var conn = DBHelper.GetDapperConnection())            {                conn.Execute(@"INSERT INTO [dbo].[MobileForTest]                               ([MobileHolder]                               ,[MobilePhone]                               ,[Status])                         VALUES                               (@MobileHolder                               ,@MobilePhone                               ,@Status)", new { MobileHolder = "InsterWithTran", MobilePhone = "18922223333", Status = 0 });            }            timer.Stop();            return timer.ElapsedMilliseconds;        }        public static long DapperLambdaSQLInsert()        {            Stopwatch timer = new Stopwatch();            timer.Start();            using (var context = DBHelper.GetContext())            {                context.Sql(@"INSERT INTO [dbo].[MobileForTest]                               ([MobileHolder]                               ,[MobilePhone]                               ,[Status])                         VALUES                               (@MobileHolder                               ,@MobilePhone                               ,@Status)").Parameter("MobileHolder", "DapperLambdaSQLInsert")                                               .Parameter("MobilePhone", "18912345678")                                               .Parameter("Status", 0).Execute();            }            timer.Stop();            return timer.ElapsedMilliseconds;        }        public static long DapperLambdaInsert()        {            List<MobileForTest> ls = new List<MobileForTest>();            Stopwatch timer = new Stopwatch();            timer.Start();            using (var context = DBHelper.GetContext())            {                context.Insert<MobileForTest>(new MobileForTest { MobileHolder = "DapperLambdaInsert", MobilePhone = "18911112222", Status = 0 }).Execute();            }            timer.Stop();            return timer.ElapsedMilliseconds;        }

 

循環500次執行,取平均耗時。

3.更新方法測試

        public static long DapperSQLUpdate()        {            Stopwatch timer = new Stopwatch();            timer.Start();            Random r = new Random();            using (var conn = DBHelper.GetDapperConnection())            {                conn.Execute("UPDATE MobileForTest SET MobileHolder = @MobileHolder WHERE ID=@ID", new { MobileHolder = "DapperSQLUpdate", ID = r.Next(1, 10000) });            }            timer.Stop();            return timer.ElapsedMilliseconds;        }        public static long DapperLambdaSQLUpdate()        {            Stopwatch timer = new Stopwatch();            timer.Start();            Random r = new Random();            using (var context = DBHelper.GetContext())            {                context.Sql("UPDATE MobileForTest SET MobileHolder = @MobileHolder WHERE ID=@ID", new { MobileHolder = "DapperLambdaSQLUpdate", ID = r.Next(1, 10000) }).Execute();            }            timer.Stop();            return timer.ElapsedMilliseconds;        }        public static long DapperLambdaUpdate()        {            Stopwatch timer = new Stopwatch();            timer.Start();            Random r = new Random();            using (var context = DBHelper.GetContext())            {                context.Update<MobileForTest>().Set(new { MobileHolder = "DapperLambdaUpdate" }).Where(p => p.ID == r.Next(1, 10000)).Execute();            }            timer.Stop();            return timer.ElapsedMilliseconds;        }

 

總體來說,測試的結果還在預期范圍之類,在使用方便和些許的性能中各位抉擇。如果有時間的話,考慮換掉Dapper,再重新比較一下。堅持。。。。

 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产91精品最新在线播放| 久久精品亚洲一区| 久久人体大胆视频| 久久久噜噜噜久噜久久| 久久频这里精品99香蕉| 国产做受69高潮| 91精品免费久久久久久久久| 亚洲欧美日韩综合| 色综久久综合桃花网| 成人黄色大片在线免费观看| 黑人巨大精品欧美一区二区免费| 欧美精品一区二区三区国产精品| 亚洲天堂av在线免费观看| 精品久久久久久久久久| 国产欧美一区二区三区视频| 亚洲国产精品成人va在线观看| 综合激情国产一区| 91精品久久久久久久| 伊人青青综合网站| 神马久久桃色视频| 欧美福利视频在线| 亚洲全黄一级网站| 国产精品一区二区三区久久| 日韩欧美高清在线视频| 欧美激情二区三区| 国产视频观看一区| 欧美资源在线观看| 国产欧美日韩亚洲精品| 亚洲第一福利网| 91精品综合久久久久久五月天| 久久久国产91| 欧美成人午夜激情在线| 午夜剧场成人观在线视频免费观看| 97热在线精品视频在线观看| 日本免费久久高清视频| 97香蕉超级碰碰久久免费软件| 日韩在线视频观看正片免费网站| 91日本视频在线| 亚洲最大成人在线| 国产精品久久久久福利| 国产一级揄自揄精品视频| 欧美亚洲国产成人精品| 精品一区二区电影| 欧美午夜精品久久久久久人妖| 国产精品女人网站| 欧美高清一级大片| 日本精品视频在线观看| 中文欧美日本在线资源| 午夜精品www| 国产成人精品电影久久久| 国内精品伊人久久| 欧美日韩一区二区三区在线免费观看| 国产精品日韩av| 亚洲精品久久久久| 国产精品一区二区三区在线播放| 亚洲天堂av综合网| 欧美激情一二三| 欧美亚洲日本网站| 日韩免费视频在线观看| 亚洲国产又黄又爽女人高潮的| 久久久久久久一| 欧美大奶子在线| 91精品国产综合久久香蕉| 久久国产精品亚洲| 亚洲欧美一区二区三区情侣bbw| 日韩av在线精品| 欧美日在线观看| 国产91网红主播在线观看| 亚洲国内高清视频| 中文字幕亚洲专区| 精品久久久久久亚洲国产300| 国产精品视频yy9099| 欧美在线视频网站| 久久久久久一区二区三区| 欧美有码在线观看| 久久久久久亚洲精品中文字幕| 日本道色综合久久影院| 亚洲老板91色精品久久| 亚洲第一国产精品| 欧美理论电影在线播放| 欧美巨乳在线观看| 国产精品毛片a∨一区二区三区|国| 欧美在线视频导航| 亚洲精品一区二区三区不| 久久久久久综合网天天| 欧美激情久久久久| 欧美日韩中国免费专区在线看| 国产成人极品视频| 亚洲精品日韩在线| 日韩精品黄色网| 国产精品流白浆视频| 成人激情av在线| 国产精品视频xxx| 九九热这里只有在线精品视| 91视频免费在线| 国语自产精品视频在免费| 69久久夜色精品国产7777| 国产精品视频久久| 欧美性高跟鞋xxxxhd| 国产91在线播放| 久久久国产一区| 91色在线观看| 超在线视频97| 亚洲国产欧美日韩精品| 精品视频9999| 中文字幕国产亚洲| 亚洲综合在线小说| 亚洲欧美在线免费观看| 91九色视频导航| 欧美性xxxxx极品娇小| 日韩在线视频国产| 久久中文字幕一区| 欧美性猛交xxxx乱大交极品| 亚洲电影在线看| 亚洲人午夜色婷婷| 欧美性生交大片免费| 97热在线精品视频在线观看| 国产精品一区二区三区成人| 日韩电影在线观看永久视频免费网站| 91国产精品91| 亚洲精品白浆高清久久久久久| 亚洲乱码国产乱码精品精天堂| 亚洲精品国产精品乱码不99按摩| 日日狠狠久久偷偷四色综合免费| 国产精品吴梦梦| 国产一区二区三区18| 久久91亚洲精品中文字幕| 亚洲国产精品高清久久久| 91丨九色丨国产在线| 欧美激情精品久久久久久变态| www国产亚洲精品久久网站| 欧美多人乱p欧美4p久久| 欧美在线免费看| 久久免费视频网| 8090成年在线看片午夜| 免费99精品国产自在在线| 91中文字幕在线| 国产香蕉精品视频一区二区三区| 97色伦亚洲国产| 欧美日韩久久久久| 色爱精品视频一区| 日韩av一区在线观看| 欧美一级淫片播放口| 激情成人在线视频| 中文字幕亚洲一区| 成人有码在线视频| 欧美福利视频在线| 亚洲国产天堂网精品网站| 亚洲成人精品视频| 在线观看精品国产视频| 欧美在线观看一区二区三区| 国产精品专区h在线观看| 精品久久久久久电影| 日韩av免费一区| 国产精品无码专区在线观看| 视频在线观看99| 97视频在线观看视频免费视频| 欧美日韩在线视频一区二区| 7777免费精品视频| 欧美高清视频在线| 国产中文字幕91| 亚洲国产精彩中文乱码av在线播放| 97久久超碰福利国产精品…| 亚洲最大av网站|