Dapper.LiteSql 一款基於Dapper的ORM

来源:https://www.cnblogs.com/s0611163/archive/2022/08/31/16641136.html
-Advertisement-
Play Games

寫了這麼久,代碼沒有越寫越多,代碼量的數量級沒變,用SourceCounter代碼統計工具統計了一下,一共4000多行代碼。 ADO.NET換成Dapper後,我迷茫了,因為LiteSql做的工作變少了,它存在的意義就變小了,代碼量也變少了。 Dapper支持所有ADO.NET支持的資料庫,我用Da ...


寫了這麼久,代碼沒有越寫越多,代碼量的數量級沒變,用SourceCounter代碼統計工具統計了一下,一共4000多行代碼。

ADO.NET換成Dapper後,我迷茫了,因為LiteSql做的工作變少了,它存在的意義就變小了,代碼量也變少了。

Dapper支持所有ADO.NET支持的資料庫,我用Dapper.LiteSql支持了ClickHouse。

在Dapper的基礎上,Dapper.LiteSql提供了哪些功能?

  1. 數據插入、更新、批量插入、批量更新,支持實體類、實體類集合,不用拼SQL了。
  2. 分頁查詢。
  3. 如果資料庫欄位名和實體類的屬性名不一致,基於Dapper的ITypeMap介面做了映射。
  4. 簡單的查詢支持Lambda表達式(支持單表條件查詢、連表條件查詢、排序、查詢數量等,不支持分組查詢、嵌套查詢、子查詢等複雜查詢)。
  5. 支持對分表進行增刪改查。
  6. 統一不同資料庫的參數化查詢SQL

以上功能,不同資料庫實現起來是有區別的,Dapper.LiteSql用最小的代價支持了更多的資料庫,只需要實現IProvider介面,就可以支持你想支持的資料庫(必須是ADO.NET支持的資料庫)。

Dapper.LiteSql滿足基本的增刪改查是夠用了,當初還是DBHelper時,我上家公司就用它來開發ERP、CRM等系統,是夠用的;其它的Dapper兜底。

LiteSql和Dapper.LiteSql

基於ADO.NET無其它依賴的版本叫LiteSql,基於Dapper的版本叫Dapper.LiteSql,後面以Dapper.LiteSql為維護重點。
最近為了完善,做了一些破壞性的修改,好在沒什麼人用,沒包袱;後續應該不會再變動介面,暫時也沒有要添加的功能了。

插入、更新、刪除功能說明

  1. 插入和更新是不需要寫SQL的
  2. 刪除可以根據ID刪,也可寫SQL條件。
  3. 如何獲取剛插入的數據的ID?提供了一個InsertReturnId介面,鑒於不同資料庫有差異,寫法也比較多,所以需要傳一個查詢插入ID的SQL,好吧,我真是機智。

查詢功能說明

典型的查詢是通過拼SQL。

int? status = 0;
string remark = "測試";
DateTime? startTime = null;
DateTime? endTime = DateTime.Now;

using (var session = LiteSqlFactory.GetSession())
{
    session.OnExecuting = (s, p) => Console.WriteLine(s);

    ISqlString sql = session.CreateSql(@"
        select t.*, u.real_name as OrderUserRealName
        from bs_order t
        left join sys_user u on t.order_userid=u.id
        where 1=1")

        .Append(" and t.status=@status", status);

        .AppendIf(!string.IsNullOrWhiteSpace(remark), " and t.remark like @remark", "%" + remark + "%");

        .AppendIf(startTime.HasValue, " and t.order_time >= @startTime ", startTime);

        .AppendIf(endTime.HasValue, " and t.order_time <= @endTime", endTime);

        .Append(" order by t.order_time desc, t.id asc ");

    long total = sql.QueryCount();
    List<BsOrder> list = sql.QueryPage<BsOrder>(null, pageModel.PageSize, pageModel.CurrentPage);
}

1. AppendIf是很有用的,在一個查詢頁面,如果有幾個查詢條件沒有選,那麼這幾個查詢條件就不會添加到SQL中。

2. 當startTime為null時,下麵的寫法是會報錯的:

sql.AppendIf(startTime.HasValue, " and t.order_time >= @startTime ", startTime.Value);

可以使用下麵的寫法:

sql.AppendIf(startTime.HasValue, " and t.order_time >= @startTime ", () => startTime.Value);

或:

sql.AppendIf(startTime.HasValue, " and t.order_time>= @startTime ", startTime);

3. 統一不同資料庫的參數化查詢SQL

例如ClickHouse的參數化查詢是這樣的:

t."captured_time" >= {StartTime:DateTime}

使用Dapper.LiteSql,你可以這樣寫:

t."captured_time" >= @StartTime

不同資料庫參數化查詢的參數統一使用@首碼

附:ClickHouse測試源碼

4. 支持Lambda表達式和原生SQL混寫,這是在開發過程中意外實現的功能,我也不知道有什麼意義

DateTime? startTime = null;

using (var session = LiteSqlFactory.GetSession())
{
    session.OnExecuting = (s, p) => Console.WriteLine(s); //列印SQL

    List<SysUser> list = session.Queryable<SysUser>() //Lambda寫法

        //拼SQL寫法
        .Append<SysUser>(@" where t.create_userid = @CreateUserId 
            and t.password like @Password
            and t.id in @Ids",
            new
            {
                CreateUserId = "1",
                Password = "%345%",
                Ids = session.CreateSql().ForList(new List<int> { 1, 2, 9, 10, 11 })
            })

        .Where(t => !t.UserName.Contains("管理員")) //Lambda寫法

        .Append<SysUser>(@" and t.create_time >= @StartTime", new { StartTime = new DateTime(2020, 1, 1) }) //拼SQL寫法

        .Where<SysUser>(t => t.Id <= 20) //Lambda寫法

        .AppendIf(startTime.HasValue, " and t.create_time >= @StartTime ", new { StartTime = startTime }) //拼SQL寫法

        .Append(" and t.create_time <= @EndTime ", new { EndTime = new DateTime(2022, 8, 1) }) //拼SQL寫法

        .QueryList<SysUser>(); //如果上一句是拼SQL寫法,就用QueryList
        //.ToList(); //如果上一句是Lambda寫法,就用ToList

    long id = session.Queryable<SysUser>().Where(t => t.Id == 1).First().Id;
    Assert.IsTrue(id == 1);

    foreach (SysUser item in list)
    {
        Console.WriteLine(ModelToStringUtil.ToString(item));
    }
    Assert.IsTrue(list.Count > 0);
}

沒什麼可講的了,就這些功能。

附:拼SQL經典示例:

DateTime? startTime = null;

using (var session = LiteSqlFactory.GetSession())
{
    session.OnExecuting = (s, p) => Console.WriteLine(s); //列印SQL

    List<SysUser> list = session.CreateSql(@"
        select * from sys_user t where t.id <= @Id", new { Id = 20 })

        .Append(@" and t.create_userid = @CreateUserId 
            and t.password like @Password
            and t.id in @Ids",
            new
            {
                CreateUserId = "1",
                Password = "%345%",
                Ids = session.CreateSql().ForList(new List<int> { 1, 2, 9, 10, 11 })
            })

        .AppendIf(startTime.HasValue, " and t.create_time >= @StartTime ", new { StartTime = startTime })

        .Append(" and t.create_time <= @EndTime ", new { EndTime = new DateTime(2022, 8, 1) })

        .QueryList<SysUser>();

    long id = session.CreateSql("select id from sys_user where id=@Id", new { Id = 1 })
        .QuerySingle<long>();
    Assert.IsTrue(id == 1);

    foreach (SysUser item in list)
    {
        Console.WriteLine(ModelToStringUtil.ToString(item));
    }
    Assert.IsTrue(list.Count > 0);
}

後續

只要代碼寫的足夠少,就...沒有BUG?嗯...最新版本暫時沒有發現BUG,因為除了我自己沒什麼人用。
使用的是Dapper的理念,不會像EFCore那樣追求強大的功能,不會追求在Lambda表達式方面做到極致,暫不會添加新功能,暫時還不知道有沒有必備功能還沒有加。

NuGet地址:

https://www.nuget.org/packages/Dapper.LiteSql

Dapper.LiteSql源碼地址:

https://gitee.com/s0611163/Dapper.LiteSql

配套實體類生成器地址:

https://gitee.com/s0611163/ModelGenerator

之前出現一個失誤,代碼註釋里含有一個敏感信息,導致我把原來的倉庫刪了,建了個新的。


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

-Advertisement-
Play Games
更多相關文章
  • 我們知道加密後的數據對模糊查詢不是很友好,本篇就針對加密數據模糊查詢這個問題來展開講一講實現的思路,希望對大家有所啟發。 為了數據安全我們在開發過程中經常會對重要的數據進行加密存儲,常見的有:密碼、手機號、電話號碼、詳細地址、銀行卡號、信用卡驗證碼等信息,這些信息對加解密的要求也不一樣,比如說密碼我 ...
  • 摘要:JVM優化的目標就是:儘可能讓對象都在新生代里分配和回收,儘量別讓太多對象頻繁進入老年代,避免頻繁對老年代進行垃圾回收,同時給系統充足的記憶體大小,避免新生代頻繁的進行垃圾回收。 本文分享自華為雲社區《千萬不要在生產環境使用這個版本的JDK,這不?記憶體又溢出了!快要裂開了!(建議收藏)》,作者: ...
  • 《Python編程快速上手》PDF高清版免費下載地址 內容簡介 · · · · · · 如今,人們面臨的大多數任務都可以通過編寫電腦軟體來完成。Python是一種解釋型、面向對象、動態數據類型的高級程式設計語言。通過Python編程,我們能夠解決現實生活中的很多任務。 本書是一本面向實踐的Pyth ...
  • “什麼是Java虛擬機,為什麼要使用”。 最近一個1年Java開發經驗的同學去面試阿裡,遇到這個問題向我求助。 大家好,我是Mic,一個工作14年的Java程式員。 那麼,這個問題,面試官希望考察什麼呢? 問題解析 Java虛擬機,是Java應用程式運行的平臺。 很多初學者,第一步基本上都是學習怎麼 ...
  • 大家好啊,我是字母哥,今天寫一篇關於etcd的文章,其實網上也有很多關於etcd的介紹,我就簡明扼要,總結提煉,期望大家通過這一篇文章掌握etcd的核心知識以及編碼技能! 本文首先用大白話給大家介紹一下etcd是什麼?這部分內容網上已經有很多了。 etcd有哪些應用場景?這些應用場景的核心原理是什麼 ...
  • 1、工廠模式 在各種BeanFactory以及ApplicationContext創建中都有用到 2、模板模式 在各種BeanFactory以及ApplicationContext創建中都有用到 3、代理模式 SpringAOP利用了AspectJ AOP實現的,Aspectj AOP的底層用的就是 ...
  • 背景: 若依前後端分離項目(vue+springboot+springmvc+mybatis),redis。 需求: 藉助redis實現對IP限流。 實現: 參考 https://blog.csdn.net/qq_33762302/article/details/116258617 代碼如下: IP ...
  • 業務場景: 近期寫的一個項目,整個項目採用的DDD(領域驅動)設計,所以剛開始設計的時候就將各個業務以聚合根的方式進行劃分,以該業務場景為例,整體的業務簡述為,當客戶進行付款以後,創建一個付款單,然後由財務手動將付款單與發貨單進行賬務沖抵和關聯,同時還需要針對付款的客戶及企業的餘額進行相應的變動,所 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...