C# NPOCO 輕量級ORM框架(入門)

来源:http://www.cnblogs.com/Aaxuan/archive/2017/08/15/7366476.html
-Advertisement-
Play Games

目前使用這個框架,搜不到中文資料。 只有英文wiki,翻譯學習摘錄一下。 大部分是機翻的,改了一些地方, 因為博主也是低水平的,標紅的是瞎理解的。 可能會有錯誤的地方,如果有園友發現可以指出。 wiki地址:http://github.com/schotime/NPoco/wiki 第一個查詢: 註 ...


目前使用這個框架,搜不到中文資料。

只有英文wiki,翻譯學習摘錄一下。

大部分是機翻的,改了一些地方,

因為博主也是低水平的,標紅的是瞎理解的。

可能會有錯誤的地方,如果有園友發現可以指出。

 wiki地址:http://github.com/schotime/NPoco/wiki

 

第一個查詢:

 1 public class User 
 2 {
 3     public int UserId { get;set; }
 4     public string Email { get;set; }
 5 }
 6 
 7 using (IDatabase db = new Database("connStringName")) 
 8 {
 9     List<User> users = db.Fetch<User>("select userId, email from users");
10 }

註: Database需要設置關閉該連接(可以把它當做你的對象)連接。

這是通過將列名映射的屬性的名稱User對象。這是不區分大小寫的匹配。
沒有使用映射(查詢)。

 

映射

 

預設情況下不需要映射。如果不指定其屬性將會假設表的名稱是類別名稱,主鍵是“ID”。

最常用的基本屬性映射是:

  1. [TableName]需要一個“名稱”參數,類將被映射到表。

  2. [PrimaryKey]表示表的主鍵列。多個鍵之間用逗號分隔。還有一個“增量”屬性,用於指示是否將自動遞增主鍵列例如標識列的SQL伺服器。預設為真。

  3. [Column]如果列名稱不匹配的使用這種屬性。

  4. [Ignore]此屬性將被忽略,並且不被映射。

  5. [ResultColumn]可映射為性能結果列,這些屬性將不被包括在插入或更新。註:需要被明確指定的SQL。它會不自動生成SQL。

  6. [ComputedColumn]標記為計算列屬性,但是他們的結果欄屬性被自動生成SQL

  7. [SerializedColumn](V3+)序列化的屬性將序列化的數據的預設實現IColumnSerializer。有npoco.jsonnet庫允許您使用JsonNetColumnSerializer

demo:

 1 [TableName("Users")]
 2 [PrimaryKey("UserId")]
 3 public class User
 4 {
 5     public int UserId { get;set; }
 6     [Column("emailAddress")]
 7     public string Email { get;set; }
 8     [ResultColumn]
 9     public string ExtraInfo { get;set; }
10     [Ignore]
11     public int Temp { get;set; }
12 }

 

查詢單個對象

 

從資料庫中查詢一個對象可以幾種不同方法來完成。

通過ID

最簡單的方式是使用 SingleById<T>()方法。

1 IDatabase db = new Database("connStringName");
2 User u = db.SingleById<User>(3);

通過SQL

下麵你可以看到,只有其中的規定。如果您不顯式提供選擇的條款將自動為您生成和在其中將隨後附上。

1 User u = db.Single<User>("where emailaddress = @0", "[email protected]");
2 or
3 User u = db.Single<User>("select u.* from users u where emailaddress = @0", "[email protected]");

這兩種方法都有一個“ordefault”方法,如果您不確定對象的存在。如果它不存在,而且您沒有使用到 ordefault 就會引發異常。

還有 First<T> FirstOrDefault<T> 如果有多條數據將拋出一個異常,如果不多於1個記錄將被返回。

 

插入,更新,刪除

插入新記錄

1 IDatabase db = new Database("connStringName");
2 User u = new User() 
3 {
4     Email = "[email protected]",
5     LastLoggedIn = DateTime.UtcNow
6 };
7 
8 db.Insert(u);

更新記錄

1 var user = db.SingleById(1);
2 user.Email = "[email protected]";
3 db.Update(user);

刪除記錄

1 var user = db.SingleById(1);
2 db.Delete(user);
3 or
4 db.Delete<User>(1);

覆蓋或新建記錄

1 IDatabase db = new Database("connStringName");
2 User u = new User() 
3 {
4     Email = "[email protected]",
5     LastLoggedIn = DateTime.UtcNow
6 };
7 
8 db.Save(u);

這樣會插入一個新記錄或更新一個現有記錄。它是否存在是由主鍵確定的。

 

查詢列表

 

獲取所有:

1 List<User> users = db.Fetch<User>();

標準獲取:

1 List<User> users = db.Fetch<User>("where isActive = 1");

使用SQL:

1 List<User> users = db.Fetch<User>("select u.* from users where u.isActive = 1");

懶惰

警告:以下方法Query<T>使用生成的關鍵字。運行該查詢的結果都被遍歷。如果你不完全理解這一概念,請使用Fetch<T>

1 List<User> users = db.Query<User>("select u.* from users where u.isActive = 1");

 

查詢分頁

主要有兩種方法用於查詢分頁。

Page<T>

1 IDatabase db = new Database("connStringName");
2 Page<T> pagedUsers = db.Page<User>(2, 10, "select u.* from users u order by userid");

其中Page<T>被定義為:

1 public class Page<T> 
2 {
3     public long CurrentPage { get; set; }
4     public long TotalPages { get; set; }
5     public long TotalItems { get; set; }
6     public long ItemsPerPage { get; set; }
7     public List<T> Items { get; set; }
8 }

註意:您必須在SQL語句中提供一個order by語句,以便查詢知道您希望將數據分頁的順序。
頁面的第一個參數是頁面編號。這個數字從第一個頁面的1開始。第二個參數是頁面的大小。在上面的示例中,將返回包含10個用戶的第二個頁面。

SkipTake<T>

SkipTake<T> 方法與在LINQ中跳過採取方法非常相似。它具有與頁面< T >方法相同的參數數量,但第一個參數不是頁碼,而是記錄的數量(即要取的記錄數量?)。第二個參數是跳過x個記錄之後返回的記錄數(即開始的位置?)。為了返回與Page<T>方法相同的結果,查詢將如下所示:

1 List<User> users = db.SkipTake<User>(10, 10, "select u.* from users u order by userid");

 

對事務的支持

 

Example 1

1 using (IDatabase db = new Database("connStringName")) 
2 {
3     db.BeginTransaction();
4     //Your CRUD operation here
5     db.CompleteTransaction();
6 }

Example 2

1 using (IDatabase db = new Database("connStringName")) 
2 {
3     using (var transaction = db.GetTransaction())
4     {
5         //Your CRUD operation here
6         transaction.Complete();
7     }
8 }

 

翻譯時間  2017/8/15


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

-Advertisement-
Play Games
更多相關文章
  • 1.首先是建審計存儲表 並建立實體 2.EF工作單元類的實現(百度有很多實現方式) 這裡的AuthUserModel是當前用戶類 3.採用Autofac.Extras.DynamicProxy實現AOP 不知道Autofac.Extras.DynamicProxy能不能直接作用在方法上? 使用Aud ...
  • 一、直接使用C#操作資料庫的類庫ADO.NET ADO.NET使用Connection對象來連接資料庫,使用Command或DataAdapter 對象來執行SQL語句,並將執行的結果返回給DataReader或DataAdapter,然後 再使用取得的DataReader或者DataAdapter ...
  • 泛型集合lisit<>優點1.性能高 對值類型使用非泛型集合類,在把值類型轉換為引用類型,和把引用類型轉換為值類型時,需要進行裝箱和拆箱的操作。裝箱和拆箱的操作很容易實現,但是性能損失較大, 假如使用泛型,就可以避免裝箱和拆箱操作。 此為集合。 ArrayList list=new ArrayLis ...
  • 經歷了很久,.net core 2.0 終於發佈了! 之前一直用的core 1.1,升級了2.0後發現認證的機制(Auth)發生了比較大的變化,在1.1中認證配置是在Configure中完成,而在2.0中,認證配置則是在ConfigureServices中完成,剛好對調了一下。 話不多說,直接看代碼 ...
  • 今天所有開發環境已經遷移到mac OS下的Visual Studio Code + 命令行編譯發佈,而運行伺服器是CentOS7,和windows沒什麼關聯了。 只要你Relese編譯併在本地有一個與伺服器相同的運行環境中運行成功了,遷移到真實伺服器不會有什麼難度。 下麵是遷移到 2.0 版本之後遇 ...
  • asp.net(c#)中String.Empty、NULL、"" 三者到底有啥區別和聯繫? ...
  • 本指南演示了以下 Azure .NET API 的用法,包括設置認證、創建並使用 Azure 存儲、創建並使用 Azure SQL 資料庫、部署虛擬機、從 GitHub 部署 Azure Web 應用。在本教程中完成的所有操作均符合1元試用條件。 開始之前 如果您還沒有 Azure 賬戶,可以申請1 ...
  • 回到目錄 對於在Linq To Entity里使用日期函數需要DbFunctions里的擴展方法,而不能使用.net里的日期函數,因為linq的代碼會被翻譯成SQL發到資料庫端,如你的.net方法對於資料庫是不知道的,所以需要使用DbFunctions里的函數,它是為sqlserver設計的,而如果 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...