Dapper.Rainbow 簡單使用

来源:http://www.cnblogs.com/EllisQian/archive/2017/07/18/7201476.html
-Advertisement-
Play Games

一. Dapper 簡介 一個效率比較高的微型ORM。 二 . Dapper.Rainbow Dapper的擴展,在這個擴展裡面實現了 Dynamic 的 插入和更新,這個對於使用動態類型的對象很有用,可以少建很多貧血型的實體類。 三 . Dynamic Dynamic 這是一把雙刃劍,在提高效率的 ...


一.  Dapper 簡介        一個效率比較高的微型ORM。   二 . Dapper.Rainbow        Dapper的擴展,在這個擴展裡面實現了 Dynamic 的 插入和更新,這個對於使用動態類型的對象很有用,可以少建很多貧血型的實體類。   三 . Dynamic        Dynamic 這是一把雙刃劍,在提高效率的同時,也增加了出錯的機會。的確要合理使用。   四.  Dapper.Rainbow的使用         
       // Api 名稱
       public virtual long Insert([Dynamic] dynamic data);
       public long InsertOrUpdate([Dynamic] dynamic data);
       public int Update(TId id, [Dynamic] dynamic data);       
       
       // 示列代碼
       new ConfigContext().Init().Job.Insert(dynamic T);
       new ConfigContext().Init().Job.InsertOrUpdate(dynamic T);
       new ConfigContext().Init().Job.Update(dynamic T)
   
        public class ConfigContext : Database<ConfigContext>
    {
        protected readonly string _connectionString;
        protected IDbConnection _connection;
        public IDbConnection Connection => _connection ?? (_connection = GetOpenConncetion());
 
       //表名
        public Table<Site> Site { get; set; }
        public Table<Job> Job { get; set; }
 
        public ConfigContext()
        {
            _connectionString = System.Configuration.ConfigurationManager.ConnectionStrings["Config_connectionString"].ConnectionString;
        }
 
        public ConfigContext Init()
        {
            return Init(Connection as System.Data.Common.DbConnection, commandTimeout: 200);
        }
 
        public IDbConnection GetOpenConncetion()
        {
            var connection = new SQLiteConnection(_connectionString);
            connection.Open();
            return connection;
        }
    }

 


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

-Advertisement-
Play Games
更多相關文章
  • 博主今日投身於SLAM的研究事業,放棄了以往win10下各種IDE的開發環境,選擇了在自己的xps13上裝上ubuntu16.04,投身於更為方便的linux進行學習和開發。 因為在xps13上安裝配置好linux實在是一件麻煩事(各種各樣的bug,以及補安裝各種各樣的驅動),博主歷盡周折才暫時配置 ...
  • 處理機的調度 標簽(空格分隔): 進程調度 調度演算法 操作系統 基本概念 定義 : 操作系統管理了系統的有限資源,當有多個進程(或多個進程發出的請求)要使用這些資源時,因為資源的有限性,必須按照一定的原則選擇進程(請求)來占用資源, 我們稱之為調度。 其目的是控制資源使用者的數量,選取資源使用者許可 ...
  • 來實驗室將近一個月,幾乎沒碰window,一直在ubuntu下開發,然後想總結一下最近常用的linux指令。 ...
  • 每個人電腦裡面都有些秘密,但是別人需要使用你的電腦時,有可能會看到,但是我們又不想讓別人發現時,我們可以將其隱藏,那麼別人就不會看到了。360文件保險柜、騰訊電腦管家等等。使用軟體繁瑣軟體過大還會拖慢系統,況且大多軟體還不能把整個盤符進行加密。下麵給大家分享一種隱藏整個盤符的方法 今天我給大家介紹的 ...
  • 介紹如何在紅帽6.5的系統中搭建Samba伺服器,windows訪問是需要進行用戶名和密碼的驗證。 ...
  • ls:列出目錄內容(預設的就是當前工作目錄了) 格式:命令 [選項] [參數] 選項: -a:列出所有文件、目錄(包含隱藏文件、目錄) -l:以長格式的方式列出 -d:僅列出目錄本身 -h:配合-l選項使用,以友好的方式,顯示文件的大小(若不加-h,預設文件大小是以byte來顯示); 實例: [ro ...
  • 1. 命令的概念 命令的執行過程 系統第一次執行外部命令時Hash緩存表為空,系統會先從PTAH路徑下尋找命令,找到後會將路徑加入到Hasa緩存中,當再次執行此命令時會直接從Hash的路徑下執行,如果存在直接執行,如果不存在將繼續從PATH下的路徑繼續查找,Hash表可以提高命令的調用速率。 命令的 ...
  • 從VSS上獲取以前的老項目,編譯時報System.Runtime.CompilerServices.ExtensionAttribute..ctor 網上寫的“刪除 Newtonsoft.Json.Net20.dll 後重新引用”,並沒有解決這個問題。 原文首發在我的主力博客 http://anfo ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...