LiteORM-For-DotNet,我的第一個開源庫

来源:https://www.cnblogs.com/michaelye/archive/2019/08/29/11431310.html
-Advertisement-
Play Games

這是一個DotNet輕量級ORM框架,解決C#.Net開發過程中重覆繁瑣的資料庫CURD操作。 前言 因工作中接手的.net項目,源碼裡面都用了動軟代碼生成的源碼做為資料庫操作類庫。其中,有些根本就沒有用到,今後也不會用到的冗餘代碼——垃圾代碼。而每次如果有表結構修改,就得重新生成表實體/手動修改實 ...


這是一個DotNet輕量級ORM框架,解決C#.Net開發過程中重覆繁瑣的資料庫CURD操作。

前言                                                                                                                                            

因工作中接手的.net項目,源碼裡面都用了動軟代碼生成的源碼做為資料庫操作類庫。其中,有些根本就沒有用到,今後也不會用到的冗餘代碼——垃圾代碼。而每次如果有表結構修改,就得重新生成表實體/手動修改實體類,然後再修改代碼中實體類邏輯,再修改DAL(資料庫訪問層)的賦值代碼、sql欄位、數據類型。

 

於是,產生一個想法,借鑒EF的理念,利用反射技術,用表實體去操作資料庫,做增、改、刪、查處理。並且,將表實體類更精細化標註,增加了欄位名、主鍵、自增長、註釋【標題】、數據類型、長度的屬性標識,更有利於實體生成更優的sql腳本。

由此,通過反射技術把所有表CUDR操作的統一處理,以前修改了表結構,就得更新表實體類、修改邏輯代碼、修改DAL。現在,只需求更新表實體及對應的邏輯代碼就可以,不用再去維護DAL代碼,幹掉那些每個DAL層中70%的代碼,達到精簡代碼,提高開發效率的目的。

有了這個想法,便開始了冗長的擼代碼,斷斷繼繼歷經兩個月的時間,終於完成了構想的雛形。然後,又花點時間去瞭解一下怎麼玩github,把源碼庫傳到上面去。放出來,讓有需要的人拿去用,希望各位看官多多指教、發表意見,大家一起改進,完善。

下麵奉上我的github地址,走過路過的都進來看看,給個Star就更好不過了。

 

詳情介紹                                                                                                                                                            

項目開源庫結構圖

 

 

 

1、YEasyModel

主要實體類反射類庫,定義實體類欄位的數據類型、長度、主鍵等特性;定義CURD方法,查詢參數表達式、排序表達式。利用lambda定義查詢邏輯,生成sql過濾條件;查詢/更新欄位定義,通過反射生成對應的Sql參數;排序邏輯定義,生成欄位排序規則;DataTable與實體類轉換方法。

2、ModelApp

winform程式,用於配置連接資料庫,定義命名空間、實體類名,生成指定的表/視圖的實體模型;

3、WebDemo

Webapi範例,簡單的表實體模型使用說明;

 

(暫時先寫這些,後面有時間再完善)

 

性能                                                                                                                                                    

以下四種不同方式查詢資料庫記錄並轉為實體類的測試:

m1DataSet實體表查詢記錄;

m2YEasyModel實體類工具查詢記錄;

m3,三層工廠模式查詢記錄,實例化一次,後面從緩存取得實例;

m4Entity Framework查詢記錄;

查詢消耗的時間單位是毫秒。

 

第一次查詢1條記錄

 

 

 

第二次查詢1條記錄

 

 

 

第三次查詢1條記錄

 

 

  

第四次連續執行50次的查詢1條記錄

 

 

  

執行1次查詢8條記錄

 

 

  

連續執行50次的查詢8條記錄

 

 

  

根據以上多種測試結果對比得出:

m1 —— DataSet排第三;

m2 —— YEasyModel其次;

m3 —— 三層工廠模式最快,因為有實例化緩存,第二次開始便不用再創建實例對象, 單條數據查詢時,速度優勢明顯。但需要維護的邏輯代碼多;

m4 —— EF最慢,且劣勢明顯;太慢了!

測試代碼:

using System;
using System.Collections.Generic;
using System.Linq;
using YEasyModel;

namespace WebApplication1.Tests
{
    static class Program
    {
        /// <summary>
        /// 應用程式的主入口點。
        /// </summary>
        [STAThread]
        static void Main()
        {
            double m1 = 0;
            double m2 = 0;
            double m3 = 0;
            double m4 = 0;
            var c = new DBContext();
            var bll = new STCT.BLL.CT_DiningInfo();
            var aa = new DataSet1TableAdapters.CT_DiningInfoTableAdapter();
            for (int i = 0; i < 50; i++)
            {
                DateTime beforDT = System.DateTime.Now;
                DataSet1.CT_DiningInfoDataTable d = aa.GetData();
                DateTime afterDT = System.DateTime.Now;
                TimeSpan ts = afterDT.Subtract(beforDT);                
                var msg = string.Format("DataSet.GetModel總共花費{0}ms.    ", ts.TotalMilliseconds);
                m1 = m1 + ts.TotalMilliseconds;

                beforDT = System.DateTime.Now;
                List<CT_DiningInfo> mmm = ModelDAL.Select<CT_DiningInfo>();
                afterDT = System.DateTime.Now;
                ts = afterDT.Subtract(beforDT);
                msg += string.Format("ModelUtil.Select 總共花費{0}ms.    ", ts.TotalMilliseconds);
                m2 = m2 + ts.TotalMilliseconds;

                beforDT = System.DateTime.Now;
                var list = bll.GetModelList("");
                afterDT = System.DateTime.Now;
                ts = afterDT.Subtract(beforDT);
                msg += string.Format("STCT.BLL.CT_DiningInfo()總共花費{0}ms.    ", ts.TotalMilliseconds);
                m3 = m3 + ts.TotalMilliseconds;

                //beforDT = System.DateTime.Now;
                //var ssss = (from a in c.DBCT_DiningInfo select a).ToList();
                ////var ll = c.DBCT_DiningInfo.AsNoTracking().ToList();
                //afterDT = System.DateTime.Now;
                //ts = afterDT.Subtract(beforDT);
                //msg += string.Format("EF Linq 總共花費{0}ms.    ", ts.TotalMilliseconds);

                beforDT = System.DateTime.Now;
                //var ssss = (from a in c.DBCT_DiningInfo select a).ToList();
                var ll = c.DBCT_DiningInfo.AsNoTracking().ToList();
                afterDT = System.DateTime.Now;
                ts = afterDT.Subtract(beforDT);
                msg += string.Format("EF總共花費{0}ms.    ", ts.TotalMilliseconds);
                m4 = m4 + ts.TotalMilliseconds;

                Console.WriteLine(msg);
                Console.WriteLine();
            }

            Console.WriteLine(string.Format("m1:{0}.      m2:{1}.      m3:{2}.      m4:{3}", m1, m2, m3, m4));
            Console.WriteLine();

            Console.Read();
        }
    }
}

  

 

總結                                                                                                                                                   

(有空再寫)

最後,奉上github地址:https://github.com/michaelyes/LiteORM-For-DotNet


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

-Advertisement-
Play Games
更多相關文章
  • 在 "上一篇文章" 中我們介紹了使用vs2019作為遠程Linux系統的開發環境,但我們是創建的傳統的sln項目,而對於Linux開發者來說以autotools或是cmake進行項目結構的組織更為簡單直觀,也符合在Linux環境上的習慣。 autotools是較為古老的也是使用最為廣泛的構建系統,你 ...
  • 已安裝的環境nginx,python3,mysql,uwsgi,virtualenv 1,創建虛擬環境 2,進入虛擬環境 3,在虛擬環境中安裝flask和uwsgi 4,配置uwsgi,在部署項目的根目錄下創建配置文件uwsgiconfig.ini,添加配置內容如下 5,配置nginx,添加如下內容 ...
  • 一、概念介紹 素數又稱為質數。一個大於1的自然數(從2開始),除了1和它本身外,不能被其他自然數整除的叫做素數,否則稱為合數。 0和1既不是素數也不是合數,最小的素數是2。 二、代碼 方法一: 註意:在for迴圈判斷時不能忘記 i <= sqrt(num) 的等號,因為假設 p*p = n , n的 ...
  • 原文:https://blog.csdn.net/LaySwift/article/details/79458947 1,vscode原生支持markdown,導出需要插件,基於node.js,需要node.js環境。2,只需要裝一個預覽插件神器:Markdown Preview Enhanced。 ...
  • 給 asp.net core 寫個中間件來記錄介面耗時 Intro 寫介面的難免會遇到別人說介面比較慢,到底慢多少,一個介面伺服器處理究竟花了多長時間,如果能有具體的數字來記錄每個介面耗時多少,別人再說介面慢的時候看一下介面耗時統計,如果幾毫秒就處理完了,對不起這鍋我不背。 中間件實現 asp.ne ...
  • 一、C#提供對面向對象編程(Object Oriented Programming)的完整支持;類描述對象的類型,而對象是類的具體實例,創建對象的過程也被稱為實例化(Instantiation);通常使用new運算符來創建對象: ※其中()實際上代表的是調用類的預設構造函數來構建類的實例; ※C#還 ...
  • 先看看netcore有哪些特性,哪些優點,與.net frameworkd 差異吧: l 跨平臺: 可以在 Windows、macOS 和 Linux 操作系統上運行。 l 跨體繫結構保持一致: 在多個體繫結構(包括 x64、x86 和 ARM)上以相同的行為運行代碼。 l 命令行工具: 包括可用於 ...
  • 1. 前言 近兩年來,很多前端的同學都開始將 VSCode 作為前端主力開發工具,其豐富的擴展給程式開發尤其是前端開髮帶來了很多便利,但是作為微軟主力語言的 .NET,卻由於有宇宙第一編輯器 Visual Studio存在,很少有看到有後端同學使用,筆者自己在 VSCode 剛出來時就折騰過將主力開 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...