asp.net core系列 66 Dapper介紹--Micro-ORM

来源:https://www.cnblogs.com/MrHSR/archive/2019/06/29/11082111.html
-Advertisement-
Play Games

一.概述 目前對於.net的數據訪問ORM工具很多,EF和EF Core是一個重量級的框架。最近在搭建新的項目架構,來學習一下輕量級的數據訪問ORM工具Dapper。Dapper支持SQL Server,MySQL,Sqlite,SqlCE,Firebird等的高性能Micro-ORM(微ORM框架 ...


一.概述

  目前對於.net的數據訪問ORM工具很多,EF和EF Core是一個重量級的框架。最近在搭建新的項目架構,來學習一下輕量級的數據訪問ORM工具Dapper。Dapper支持SQL Server,MySQL,Sqlite,SqlCE,Firebird等的高性能Micro-ORM(微ORM框架)。最新版本是1.60.16。

    Dapper擴展了IDbConnection介面,例如實現一個查詢方法,Dapper定義的一個Query查詢方法如下:

  public static IEnumerable<T> Query<T>(this IDbConnection cnn, string sql, object param = null, SqlTransaction transaction = null, bool buffered = true)

    原生態ado.net的System.Data.SqlClient也實現了IDbConnection介面,可參考如下:

    https://docs.microsoft.com/en-us/dotnet/api/system.data.idbconnection?redirectedfrom=MSDN&view=netframework-4.8

    Dapper開源地址:https://github.com/StackExchange/Dapper

    Dapper Nuget包: https://www.nuget.org/packages/Dapper/

 

  Dapper的主要特征包括:

    (1)     支持強類型。如查詢 Query<T>

    (2)     支持動態對象。在Dapper. Rainbow擴展包中有實現

    (3)     使用Execute執行執行T-SQL腳本塊,不返回結果。

    (4)     批量執行SQL語句。

    (5)     “性能”是Dapper的一個亮點。官方列出了查詢(select)與其它的ORM工具性能的對比參數。

    (6)     參數化查詢

    (7)     列表支持

    (8)     字面替換

    (9)     對於查詢的緩衝與無緩衝,預設行為是緩衝將數據交給了後端List,獲得數據後,就釋放了任何資源(減少了資料庫共用鎖等)。對於大量查詢(比如:>100條),需要將緩衝行為關閉,避免占用太多記憶體,設置buffered:false的Query方法。  “註意緩衝不是緩存”。

        dapper buffer/cache

    (10)  實體中外鍵關係表映射。

    (11)  允許單個查詢請求,查詢多個表。如:select table1,select table2

    (12)  支持程式中資料庫事務處理。

 

  Dapper註意事項:

    (1) Dapper緩存用來保存每個查詢的信息,緩存在ConcurrentDictionary對象中,如果不使用參數的情況下動態生成sql字元串,則可能會遇到記憶體問題。

    (2) Dapper的簡潔性意味著ORM附帶的許多功能都被剝離了。它擔心95%的情況,併為您提供大多數時間所需的工具。它並不試圖解決所有問題。

 

二. Dapper源代碼包

  2.1 Dapper.Contrib包

    Dapper.Contrib是包含許多用於CURD的輔助方法Contrib的關鍵組成部分是它為您的實體提供跟蹤,以確定是否已進行更改。與EF一樣GET出來的實現,在Update方法時,僅更新已更改的屬性所需的SQL。Dapper.Contrib中的擴展方法的完整列表,可以看出方法都是強類型

T Get<T>(id);
IEnumerable<T> GetAll<T>();
int Insert<T>(T obj);
int Insert<T>(Enumerable<T> list);
bool Update<T>(T obj);
bool Update<T>(Enumerable<T> list);
bool Delete<T>(T obj);
bool Delete<T>(Enumerable<T> list);
bool DeleteAll<T>();

    Dapper將自動使用名為“ id”(不區分大小寫)的屬性作為Key 屬性(所以數據表中最好以ID名稱為主鍵), 如果實體不遵循此約定,請使用[Key][ExplicitKey]屬性修飾特定屬性。[Key]應該用於資料庫生成的鍵(例如自動增量列),而[ExplicitKey]應該用於代碼中生成的顯式鍵值

public class User
{
    [Key]
    int TheId { get; set; }
    string Name { get; set; }
    int Age { get; set; }
}

    Dapper.Contrib使用了一些可選屬性:[Table("Tablename")] - 使用另一個表名而不是類的名稱,如下示例:

[Table ("emps")]
public class Employee
{
    public int Id { get; set; }
    public string Name { get; set; }
} 

    [Write(true/false)] - 這個屬性是(不)可寫的
    [Computed] - 此屬性已計算,不應作為更新的一部分

   具體參考 https://github.com/StackExchange/Dapper/tree/master/Dapper.Contrib

 

  2.2 Dapper.EntityFramework包

    Dapper.EntityFramework和Dapper.EntityFramework.StrongName依賴了entityframework 6.1.3 的DbGeography類和Microsoft.SqlServer.Types的SqlGeography類,  從資料庫中讀取幾何和地理值時,我們需要明確指定SRID以將其保留在DbGeometry / DbGeography類型中。

 

  2.3 Dapper. Rainbow包

    Rainbow是一個Abstract類,可以將其用作Dapper類的基類,實現CURD的方法,以Dynamic為主的動態類型用於插入、更新、以及查詢參數的實現,輸出返回強類型。Rainbow希望你的所有表都有一個名為“Id”的標識列,在Dapper源代碼解決方案下沒有Dapper. Rainbow組件的測試案例

    Contrib和Rainbow之間的主要區別在於:一個跟蹤您實體的變化,另一個不跟蹤:

    (1)  如果希望能夠跟蹤實體中的更改,請使用Contrib。

    (1)  當您想要使用更符合標準ADO.NET方法的內容時,請使用Rainbow。

 

  2.4 Dapper.SqlBuilder包

    Dapper.SqlBuilder組件,用於動態構建SQL查詢。

 

  2.5  Dapper.StrongName與Dapper包

    StrongName包下的所有類文件都是來源於Dapper包中的類,支持SQL Server,MySQL,Sqlite,SqlCE,Firebird等的高性能Micro-ORM, 用於強名稱,使用SqlMapper來實現ADO.NET的輕量級對象映射器。

 

三.其它擴展包

  3.1 Dapper. SimpleCRUD

    SimpleCRUD是一個簡單CRUD助手,可以選擇更改資料庫方言。預設為Microsoft SQL Server,但可以更改為PostgreSQL或MySQL。放棄了.Net Core版本的SQLite支持(在新項目中實用)。

  3.2 Dapper.Extensions.NetCore

    Dapper是一個簡單的CRUD助手。在Nuget上還有其它Dapper.Extensions.xx的擴展包。

 


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

-Advertisement-
Play Games
更多相關文章
  • 1.主體函數 2. 相關函數 3.實驗 4.結果 ...
  • m3u8解析、轉碼、下載、合併 現在網也上大多數視頻需要下載都很麻煩,極少數是MP4,大多都是m3u8, 先說視頻下載, pc端: 打開網頁,點擊視頻播放,打開開發者工具,找到網路那一欄, 等整個網頁載入完成後,可以再下圖指示的地方進行搜索,搜mp4.或者m3u8,搜出來之後,滑鼠右鍵複製鏈接, 在 ...
  • 1.運行程式 python 使用cmd.exe 運行程式。 例子: python +【文件路徑】 2.註釋 當行註釋:# 被註釋內容 多行註釋:'''被註釋內容''',或者"""被註釋內容""" 3.縮進 python 中作用域通過縮進控制 頂級代碼必須頂行寫,即如果一行代碼本身不依賴於任何條件,那 ...
  • 命名空間 從python解釋器開始執行之後,就在記憶體中開闢了一個空間,每當遇到一個變數的時候,就把變數名和值之間的對應關係記錄下來。但是當遇到函數定義的時候解釋器只是象徵性的將函數名讀入記憶體,表示知道這個函數的存在了,至於函數內部的變數和邏輯解釋器根本不關心。等執行到函數調用的時候,python解釋 ...
  • Spring框架的主要功能是通過其核心容器來實現的。Spring提供了2種核心容器:BeanFactory、ApplicationContext。 BeanFactory BeanFactory是一個管理Bean的工廠,主要負責初始化各種Bean,並調用它們的聲明周期方法。 BeanFactory由 ...
  • 最近在學習python,分別在Ubuntu和win10環境下安裝了pycharm,最初學習基礎知識是在Ubuntu下進行的。 想試試在win10下練練手,自然也就想到了釋放出一個可執行文件試試。 我參考了百度經驗去做 利用pyinstaller來進行打包,沒有成功。 經過一番查閱資料,找到瞭解決辦法 ...
  • .Net for Spark 實現WordCount應用及調試入坑詳解 1. 概述 iNeuOS雲端操作系統現在具備物聯網、視圖業務建模、機器學習的功能,但是缺少一個計算平臺產品。最近在調研使用什麼語言進行開發,並且研究實現的技術路線。iNeuOS全系使用C#/JS/CSS/PYTHON開發,所以優 ...
  • 之前做的一個資料庫小工具可以支持根據 Model 代碼文件生成創建表的 sql 語句,原來是基於 CodeDom 實現的,最近改成使用基於 Roslyn 去做了。實現的原理在於編譯選擇的Model 文件生成一個程式集,再從這個程式集中拿到 Model (資料庫表)信息以及屬性信息(資料庫表欄位信息)... ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...