讓你的Dapper像EF一樣調用 開源~!

来源:http://www.cnblogs.com/frame943581425/archive/2017/08/10/7341381.html
-Advertisement-
Play Games

什麼是Dapper? Dapper是一款輕量級的ORM框架,大名鼎鼎! 由谷歌Google 開發,在N款orm框架中 效率是最快的 最高的! 經過數據測試 比EF快 12-20 倍 國外最大的技術網站 stackoverflow 也是基於這個Orm框架開發的,並且非常簡單。 為什麼使用Dapper? ...


什麼是Dapper?


        Dapper是一款輕量級的ORM框架,大名鼎鼎! 由谷歌Google 開發,在N款orm框架中 效率是最快的 最高的! 經過數據測試 比EF快 12-20 倍

        國外最大的技術網站 stackoverflow 也是基於這個Orm框架開發的,並且非常簡單。

 

為什麼使用Dapper?


  1. 輕量。只有一個文件(SqlMapper.cs),編譯完成之後只有120k(好象是變胖了)
  2. 速度快。Dapper的速度接近與IDataReader,取列表的數據超過了DataTable。
  3. 支持多種資料庫。Dapper可以在所有Ado.net Providers下工作,包括sqlite, sqlce, firebird, oracle, MySQL, PostgreSQL and SQL Server
  4. 可以映射一對一,一對多,多對多等多種關係。
  5. 性能高。通過Emit反射IDataReader的序列隊列,來快速的得到和產生對象,性能不錯。
  6. 支持FrameWork2.0,3.0,3.5,4.0,4.5 .....

 

正文


對Dapper做了簡單介紹, 有關Dapper優點的文章網上一大堆, 這裡小編就不再贅述啦!   進入正題 相信很多園友的公司都使用過微軟的EF框架吧?

EF的優點太多了  “CodeFist代碼優先”、" 不需要為數據訪問編寫所有需要的ADO.NET管道代碼"、"使用C#代碼來編寫所有的數據訪問邏輯而不是編寫SQL查詢和存儲過程"等等....

但是最大的缺點就是過於臃腫 龐大  性能不咋地 ! 出於這個原因 ! 很多公司都放棄採用這個框架, 選擇使用自己封裝的SqlHelper類或其它第三方orm框架 

但是由於被EF慣壞了 讓小弟覺得其它的ORM框架都沒EF便捷 快速 於是小弟想能不能把現今最流行的Dapper改成類似EF的調用模式! 所以這篇博客出來了!

 

先看幾個例子

操作數據表的數據

 --------------------------例子(一)------------------------

//Dapper原生 根據Id獲取數據
string query = "SELECT * FROM Book WHERE id = @id"; book = conn.Query<Book>(query, new { id = id }).SingleOrDefault(); //經過小弟Dapper改裝後 var id = 0001;//根據Id查詢數據 T_Example entity=_repExample.GetById(id);

--------------------------例子(二)----------------------------

//Dapper原生 獲取數據表總項數
var count= conn.ExecuteScalar<int>("SELECT COUNT(*) FROM customers Where Type=A"); //經過小弟Dapper改裝後 //獲取數據表總數 var count01= _repExample.GetCount(); //不帶條件 var count02 =_repExample.GetCount(item => item.Age > 30 && item.CreateTime<new DateTime(2017,8,10));//帶條件


-------------------------例子(三)-------------------------------------
//Dapper原生獲取第一條數據 var entity= _Conn.QueryFirst<T_Example>("Select* from T_Example where Name==啊爆g");
//經過小弟Dapper改裝後
var entity = _repExample.GetFist(item => item.Name == "啊爆g");//使用lambda式


-------------------------------例子(四)---------------------------------------
//Dapper原生檢查數據是否存在 var count= conn.ExecuteScalar<int>("SELECT COUNT(*) FROM customers Where Type=A"); return count>0; //通過判斷count是否大於0 //經過小弟Dapper改裝後 bool IsExist= _repExample.Exists(item => item.Phone == "10086");

 

 數據的 增刪改 操作

---------------------------例子(一)-------------------------------------------

//
dapper原生Insert插入數據 Book book = new Book(); book.Name="C#本質論"; string query = "INSERT INTO Book(Name)VALUES(@name)"; //對對象進行操作 conn.Execute(query, book); //直接賦值操作 conn.Execute(query, new {name = "C#本質論"});

//經過小弟Dapper改裝後
T_Example item
= _repExample.Insert(entity);//單挑插入 bool succ= _repExample.Insert(entityList);//批量插入 內置事物操作 失敗其中一條錯誤 全部回滾

--------------------------例子(二)-------------------------------------------
//daper原生Update更新數據 string query = "UPDATE Book SET Name=@name WHERE id =@id"; conn.Execute(query, book); //經過小弟Dapper改裝後

var entity = new T_Example() ; T_Example item= _repExample.Update(entity);//單條模型更新 bool succ= _repExample.Update(entityList);//批量更新 內置事物操作 失敗其中一條錯誤 全部回滾 bool succ = _repExample.Update(id,new { Name="張三",Age=22});//部分欄位更新
------------------------------例子(三)--------------------------------------------
//dapper原生Delete刪除數據 string query = "DELETE FROM Book WHERE id = @id"; conn.Execute(query, book); conn.Execute(query, new { id = id }); //經過小弟Dapper改裝後 var entity = new T_Example() ; T_Example item= _repExample.Delete(id);//刪除數據 單條 bool succ= _repExample.Delete(IEnumerable<object> ids);//批量刪除 內置事物操作 失敗其中一條錯誤 全部回滾

 

數據查詢操作實例

//dapper原生查詢
string query = "SELECT * FROM Book Where Name Like %C#%";
//無參數查詢,返回列表,帶參數查詢和之前的參數賦值法相同。
conn.Query<Book>(query).ToList();

//經過小弟改裝後

_repExample.GetAll();
//獲取數據表所有數據 _repExample.GetAll(new { Name = true });//欄位排序true 升序 false降序 //根據條件獲取數據 _repExample.GetTableData(item => item.Age > 20 && item.Name.Contains("C#%")); //開頭模糊查詢 _repExample.GetTableData(item => item.Age > 20 && item.Name.Contains("%深入理解C#%"));//包含模糊查詢 _repExample.GetTableData(item => item.Age > 20 && item.Name.Contains("%Join Skeet"));//結尾模糊查詢 //分頁查詢 long pageTotal;//輸出當前表總項數 _repExample.GetPageData(1, 20, out pageTotal); _repExample.GetPageData(1, 20, out pageTotal, item => item.Age > 30);//根據條件分頁 //獲取視圖數據 _repExample.QueryView<ExampleBusinessModel>("View_視圖名稱"); _repExample.QuerySql<T_Example>("select Name,Age,Phone from T_Example");//執行原生Sql

 

 

多表事物操作實例

//dapper的事物處理就不貼出代碼了
//只貼小弟Dapper改裝過後的代碼
  var succ=_repExample.Submit(tran =>
            {
                //在這裡執行你具體的事物操作       
                _repExample.InsertTran(new T_Example(),tran);//A表插入一條數據  
                _repLog.DeleteTran(id, tran);   //再刪除B表的數據

            });

 

還有很多封裝方法 小弟還來沒有時間擴展 現在小弟把代碼開源 你可以根據自己的需求進行擴展

 雖然小弟只有3年半 編程經驗 但是自認為代碼還是寫的規範  源碼都有註釋 很容易懂 有什麼意見歡迎質詢小弟 小弟QQ407015811

 

 

我媽媽叫我睡覺了~~~ 明天還要上班, 源碼 我明天放上來!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 如果你的伺服器的總是報告記憶體不足,並且時常因為記憶體不足而引發服務被強制kill的話,在不增加物理記憶體的情況下,啟用swap交換區作為虛擬記憶體是一個不錯的選擇,如果是SSD硬碟,正常讀寫速度都在300MB/s以上,啟用swap後性能提高了不少,特別是在處理消耗大記憶體的腳本方面。 ...
  • 0x00. Command Notation[Name] The name of the command.[Format] The code sequence. [ ]k indicates the contents of the [ ] s... ...
  • 聲明:本文為轉載的文章;並非由本人創作;發博文只是為了整理、記錄。 推薦的比較完全,比較清晰的文章(含圖):http://blog.csdn.net/sunny04/article/details/40627311 轉載時請註明出處和作者聯繫方式:http://blog.csdn.net/absur ...
  • 本文目錄: 1.8.1 匿名管道"|" 1.8.2 重定向 1.8.2.1 重定向基礎 1.8.2.2 cat和重定向配合 1.8.2.3 tee雙重定向 1.8.2.4 <<和<<< 1.8.1 匿名管道"|" 管道符號意如其名,類似管道一樣將管道入口的數據通過管道傳遞給管道出口。 管道是為瞭解決 ...
  • 由於業務的關係我們用的是阿裡雲的ECS主機,需要對業務進程需要監控,查看後發現阿裡雲提供自定義監控SDK,這有助於我們定製化的根據自身業務來做監控,下麵我就根據業務需求來介紹一個簡單的自定義監控配置 備註:我用的shell腳本用來部署的 業務需求:我們需要監控ECS伺服器中某個進程是否存在,如果小於 ...
  • DHCP前身是BOOTP,在Linux的網卡配置中也能看到顯示的是BOOTP,DHCP引進一個bootp沒有的概念:租約。bootp分配的地址是永久的,而dhcp分配的地址是可以有期限的。 DHCP可以自動分配IP、子網掩碼、網關、DNS。 DHCP客戶端使用的埠68,服務端使用埠67,使用的U ...
  • 在nginx中配置偽靜態,也就是常說的url重寫功能,只需在nginx.conf配置文件中寫入重寫規則即可。 當然,這個規則是需要熟悉正則表達式,只掌握nginx自身的正則匹配模式即可,對正則不瞭解的朋友,建議補一下這方面的知識。 下麵,收集了幾篇關於nginx rewrite重寫的教程文章,感興趣 ...
  • 前面幾章介紹了 ASP.NET Core Logging 系統的配置和使用,而對於 Provider ,微軟也提供了 Console, Debug, EventSource, TraceSource 等,但是沒有我們最常用的 FilePrivider,而比較流行的 Log4Net , NLog 等也 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...