輕量級ORM《sqlcommon》第一個版本發佈了!!!

来源:https://www.cnblogs.com/chaeyeon/archive/2019/10/25/11738555.html
-Advertisement-
Play Games

一、sqlcommon的特色 1. 輕量級,整個包只有123kb。 2. 性能好,自測。。。 3. API和功能簡單、代碼簡短、可維護性好基本都能看懂。這個點我認為很重要,你不用為了實現一個需求而四處查資料,這意味著這個包你可以自行維護修改(修改版只限自己使用尊重一下作者創作權)。 4. 面向ADO ...


一、sqlcommon的特色

1. 輕量級,整個包只有123kb。

2. 性能好,自測。。。

3. API和功能簡單、代碼簡短、可維護性好基本都能看懂。這個點我認為很重要,你不用為了實現一個需求而四處查資料,這意味著這個包你可以自行維護修改(修改版只限自己使用尊重一下作者創作權)。

4. 面向ADO.NET標準介面實現強大的相容,不依賴具體資料庫驅動程式。支持netframwork4.5及以上,和所有相容standard2.0的.net框架

5. 組件獨立,sqlcommon的幾大核心組件,都是可以獨立起來使用的,比如你不會寫IL你就可以利用我寫的繼續擴展查詢API

6. github:https://github.com/1448376744/SqlCommon

7. nuget:https://www.nuget.org/packages/SqlCommon

二、sqlcommon的極大核心組件

  sqlcommon分為common和expression兩個文件夾。common文件夾中包含一個輕量級的orm功能類似《dapper》980行代碼。expression文件夾中包含linq語法糖,用於自動生成sql。

1.TypeConvert-類型轉換器

這個API是用來解序列的,底層採用IL動態創建解碼函數(緩存),實際上會比直接反射性能略好

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

這個API是用於序列化對象將DataReader與實體類型進行動態綁定,底層採用IL實現

2. TypeMapper-類型映射

 這個API定義了綁定實體類型中的每個屬性的規則,在TypeMapper中有定義,你可以通過實現ITypeMapper介面,來編寫自己的TyperMapper,

來定製化屬性映射規則,屬性名和欄位名映射規則。具體可以參照我的源代碼

var handler = TypeConvert.GetSerializer<Student>(new CustomMapper(), reader);

 3. SqlMapper-sql映射

支持多結果集並行查詢

  多參數類型支持

 三、linq語法糖,更多用列請查看github

如果喜歡我的這個linq但是不想使用我的sqlmapper的,可以用你喜歡的ORM實現一下IDbContext介面,然後吧SqQuery擴展到你的資料庫上下文對象上。具體可以參考我的From實現

 


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

-Advertisement-
Play Games
更多相關文章
  • 使用LinqDB查詢Sqlite資料庫數據,不管是大數據還是少量的數據,感覺特別耗時,尤其是首次查詢 一個含有2.7萬條數據的數據表 首次查詢: 查詢2.7萬條數據,耗時1s 查詢8條數據,也要耗時750ms 二次查詢: 查詢2.7萬條數據,耗時475ms 查詢指定的1條數據,耗時73ms 我們來嘗 ...
  • 當使用Sql語句查詢資料庫,返回DataSet數據集。 DataSet轉化為數據列表,可以通過映射方式直接返回Entity數據列表 新建一個特性類,用於資料庫列表列名稱映射 LinqToDB提供了一個ColumnAttribute,但是通過反射不方便獲取ColumnAttribute獲取Custom ...
  • 一、簡介 1.break語句:迴圈-迴圈中斷並停止,退出當前迴圈; 流程圖: 2.continue:迴圈-迴圈下一次迭代繼續執行。 流程圖: 執行過程:立即結果本次迴圈,判斷迴圈條件,如果成立,則進入下一次迴圈,否則退出本次迴圈。 舉例:我編寫的代碼時候,上個廁所,回來繼續編寫代碼。 二、實例 練習 ...
  • 一、簡介 嵌套迴圈:while、for和do...while迴圈使用一個或者多個嵌套。 二、實例 輸出九九乘法表(迴圈的嵌套) 輸出結果 ...
  • 場景 DevExpress的TreeList怎樣給樹節點設置圖標: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102745542 在上面這篇博客中有具體的應用。 註: 博客主頁:https://blog.csdn.net/ba ...
  • 一、簡介 在for和while的迴圈是在頭部寫測試迴圈條件,而do....while的迴圈是在迴圈的尾部寫測試條件 do...while的迴圈和while的類似,但是do...while的最少執行一次迴圈體。 二、語法 do{ 迴圈體; } while{ 條件; } 三、執行過程 程式先執行do{} ...
  • 場景 DevExpress的TreeList怎樣設置數據源使其顯示成單列樹形結構: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/102742426 在上面設置TreeList的數據源並設置其為樹形結構後,如何給樹形結構設置圖標 ...
  • 一、簡要說明 文章信息: 基於的 ABP vNext 版本:1.0.0 創作日期:2019 年 10 月 24 日晚 更新日期:暫無 ABP vNext 提供了後臺工作者和後臺作業的支持,基本實現與原來的 ABP 框架類似,並且 ABP vNext 還提供了對 HangFire 和 RabbitMQ ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...