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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...