FluentData微型ORM

来源:http://www.cnblogs.com/jiangbiao/archive/2016/04/06/5359068.html
-Advertisement-
Play Games

最近在幫朋友做一個簡單管理系統,因為筆者夠懶,但是使用過的NHibernate用來做這中項目又太不實際了,索性百度了微型ORM,FluentData是第一個跳入我眼睛的詞。簡單的瞭解下FluentData使用,主要看看是不是符合筆者的要求。嗯……嗯……反應還不錯,API使用也很簡單,參數化查詢、分頁 ...


  最近在幫朋友做一個簡單管理系統,因為筆者夠懶,但是使用過的NHibernate用來做這中項目又太不實際了,索性百度了微型ORM,FluentData是第一個跳入我眼睛的詞。簡單的瞭解下FluentData使用,主要看看是不是符合筆者的要求。嗯……嗯……反應還不錯,API使用也很簡單,參數化查詢、分頁什麼的都有了,好了就它了,下麵還是本篇的正題,怎麼使用它。

 1、下載

  http://fluentdata.codeplex.com/

  這裡需要註意的是,FluentData需要.NET4.0的支持,同時支持dynamic,支持的資料庫有:

  • MS SQL Server
  • MS SQL Server Compact 4.0
  • MS SQL Azure
  • MS Access
  • Oracle
  • MySQL
  • SQLite
  • PostgreSQL
  • IBM DB2
  • Sybase

 2、使用

  說說簡單的增、刪、改、查,創建並且初始化一個IDbContext,函數中第一個參數為資料庫鏈接字元串,第二個參數為資料庫類型

public static IDbContext Context()
        {
            var context = new DbContext().ConnectionString(ConnectionString, new SqlServerProvider());
            return context;
        }

新增使用:

var MembershipId = FluentDataHelper.Context().Sql("insert into Membership(Name,Address) values(@0,@1)").Parameters("張三", "長沙").ExecuteReturnLastId<int>();

Or

var Insert = FluentDataHelper.Context().Insert("Membership")
                      .Column("Name", Name)
                      .Column("Address", Address);     
if (ImageByte != null) Insert.Column("Image", ImageByte); int MembershipId = Insert.ExecuteReturnLastId<int>();

 刪除使用:

int RowId = FluentDataHelper.Context().Sql("delete Membership where Id = @Id").Parameter("Id", Id).Execute();

Or

int RowId = FluentDataHelper.Context().Delete("Membership").Where("Id", Id).Execute();

修改使用:

int RowId = FluentDataHelper.Context().Sql("update Membership set Name = @Name where Id = @Id").Parameter("Name", Name).Parameter("Id", EditId).Execute();

Or

var Update = FluentDataHelper.Context().Update("Membership")
                     .Column("Name", Name)
                     .Where("Id", EditId);

                if (ImageByte != null)
                    Update.Column("Image", ImageByte);

                int RowId = Update.Execute();

 查詢使用:

//返回單個值
int RowId = FluentDataHelper.Context().Select<int>("Count(1)")
                         .From("Membership")
                         .Where("Tel = @Tel").Parameter("Tel", Tel)
                        .AndWhere("Id != @Id").Parameter("Id", EditId)
                         .QuerySingle();
//返回實體
MembershipEntity Entity = FluentDataHelper.Context().Select<MembershipEntity>("*")
                    .From("Membership")
                    .Where("Id = @Id").Parameter("Id", EditId)
                    .QuerySingle();
//返回多個對象
List<MembershipGroupEntity> ListGroup = FluentDataHelper.Context().Select<MembershipGroupEntity>("*")
                .From("MembershipGroup")
                .QueryMany();
//多表關聯及分頁
var select = FluentDataHelper.Context()
                  .Select<VehicleEntity>("Vehicle.*,AdminUser.Name as AdminName,Membership.Name as MembershipName,Membership.Tel,Membership.CardId,Membership.Address,Membership.Source")
                  .From("Vehicle left join AdminUser on Vehicle.AdminId = AdminUser.Id left join Membership on Vehicle.MembershipId = Membership.Id")
                  .OrderBy("Vehicle.Time desc")
                  .Paging(pageInfo.PageIndex, pageInfo.PageSize);

            if (!string.IsNullOrEmpty(Name))
            { 
                select.AndWhere("Membership.Name like @Name").Parameter("Name", string.Format("%{0}%", Name));
            }
            if (!string.IsNullOrEmpty(Code))
            {
                select.AndWhere("Code = @Code").Parameter("Code", Code);
            }

            this.GridViewVehicle.DataSource = select.QueryMany();

事務使用:

//反生異常,事務自動回滾
using (var context = FluentDataHelper.Context().UseTransaction(true))
                {
                    context.Sql("update Membership set Name = @0 where Id = @1")
                                .Parameters("李四", 12)
                                .Execute();

                    context.Sql("update Product set Name = @0 where Id = @1")
                                .Parameters("Product不存在資料庫中", 1)
                                .Execute();
                    context.Commit();
                }

好了,基本簡單的使用到此就已經結束了,如果有興趣的朋友可以去看看這個的源碼,這個是開源的,而且拓展性也是很不錯的。

作者:InNet
出處:http://www.cnblogs.com/jiangbiao/
本文版權歸作者和博客園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接,否則保留追究法律責任的權利。


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

-Advertisement-
Play Games
更多相關文章
  • 介紹 grep是一個功能強大的文本搜索命令,可以用它來搜索某個文件中是否包含指定的搜索內容,它可以利用正則表達式來做複雜的篩選操作,它還可以為其它命令傳輸給管道的篩選,比如我們常用到的分析單個進程的操作就是會利用它“ps -ef|grep command”。 語法 grep [OPTION]... ...
  • 一、關於CentOS系統介紹 CentOS(Community Enterprise Operating System,中文意思是:社區企業操作系統)是Linux發行版之一,它是來自於Red Hat Enterprise Linux依照開放源代碼規定釋出的源代碼所編譯而成。基於Red Hat持續升級 ...
  • 1 引言 相關源碼下載地址:http://www.jinhusns.com/Products/Download/?type=xcj 1.1 目的 用於社會化開發平臺的架構設計指導,闡述基礎設施及關鍵技術構件、業務構件的設計思想及具體實現。 讀者包括但不限於社會化開發平臺的研發人員,使用社會化開發平臺 ...
  • SSIO的更新 在SSIO上增加了UDP通訊方式,可以到Github上下載源代碼。在原來的項目中,遠端的設備與中心站的數據交互並沒有使用過UDP方式。這種短連接的通訊鏈路,不容易維護,主要體現在:(1)持續的數據交互能力。(2)對現場設備進行長時間的維護和校準。(3)SSIO要協調設備、IO和控制方 ...
  • 集合:可以使用集合來維護對象組。 C#中的數組實現為 System.Array 類的實例,它們只是集合類(Collection Classes)中的一種類型。集合類一般用於處理對象列表,其功能比簡單數組要多,功能大多是通過實現 System.Collections 名稱空間中的介面而獲得的, 因此集 ...
  • 首先先套用一下書中對於委托的描述 什麼是委托,法庭上律師為當事人辯護,他真正執行的是當事人的陳詞,律師就相當於一個委托對象,而當事人則委托律師對象為自己辯護。 C#中的委托概念就好比律師對象,它是一個類(“委托是類類型”),因為只有類對象才有對象的概念。 C#中的委托可以理解為函數的一個包裝,它可以 ...
  • 1、通過JavaScript獲取本機的時間,自動更新 <script> function displayTime() { var date = new Date(); //日期對象 var now = ""; now = date.getFullYear() + "年"; now = now + ( ...
  • 演算法實例 排序演算法Sort 歸併排序MergeSort 演算法說明 1. 歸併的思路是任意兩個元素可以比較大小,那麼任意兩個有序的元素集合也可以通過比較大小的方式歸併成一個有序的元素集合 2. 任何的無序元素集合可以拆分的最小的可比較單位是元素本身,例如List list = new List() { ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...