欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

在C#中如何使用Dapper詳解(譯)

 更新時(shí)間:2018年09月11日 15:21:14   作者:yixuan.han  
這篇文章主要給大家介紹了關(guān)于在C#中如何使用Dapper的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起看看吧

前言:

Dapper是一款輕量級ORM工具。如果你在小的項(xiàng)目中,使用Entity Framework、NHibernate 來處理大數(shù)據(jù)訪問及關(guān)系映射,未免有點(diǎn)殺雞用牛刀。你又覺得ORM省時(shí)省力,這時(shí)Dapper 將是你不二的選擇。

對象關(guān)系映射(ORM)已經(jīng)被使用了很長時(shí)間,以解決在編程過程中對象模型與數(shù)據(jù)模型在關(guān)系數(shù)據(jù)庫中不匹配的問題。

Dapper是由Stack OverFlow團(tuán)隊(duì)開發(fā)的開源的,輕量級的ORM.相比于其他的ORM框架,Dapper速度非???。

Dapper的設(shè)計(jì)考慮到了性能以及易用性。它支持使用事務(wù),存儲(chǔ)過程或數(shù)據(jù)批量插入的靜態(tài)和動(dòng)態(tài)對象綁定。

本文將給大家詳細(xì)介紹關(guān)于C#使用Dapper的相關(guān)內(nèi)容,下面話不多說了,來一起看看詳細(xì)的介紹吧

下載和安裝Dapper:

要開始使用Dapper,請遵循以下步驟:

1.打開Visual Studio

2.點(diǎn)擊文件(File)->新建(New)->項(xiàng)目(Project)
3.從新建項(xiàng)目對話框中選擇Web->ASP.Net Web Application

4.為項(xiàng)目指定一個(gè)名稱

5.選擇空項(xiàng)目模板

6.點(diǎn)擊“確定”

以上將創(chuàng)建一個(gè)空的ASP.Net應(yīng)用程序項(xiàng)目。

注:如果你已經(jīng)安裝了NuGet,你可以使用NuGet來安裝Dapper->在解決方案資源管理器中選中項(xiàng)目,右擊項(xiàng)目選擇“管理Nuget包...”,找到Dapper進(jìn)行安裝,成功之后就可以到下一步啦。

在.NET中使用Dapper進(jìn)行CRUD操作:

現(xiàn)在讓我們寫一些代碼,使用Dapper對數(shù)據(jù)庫進(jìn)行CRUD操作,首先創(chuàng)建一個(gè)名為“IDG”的數(shù)據(jù)庫,它包含一個(gè)名為“Author”的表,表中包含以下字段:ID,FirstName,LastName。

然后我們需要?jiǎng)?chuàng)建一個(gè)實(shí)體類(POCO類),下面是與數(shù)據(jù)庫IDG中Author表相對應(yīng)的實(shí)體類Author:

public class Author
 {
  public int Id { get; set; }
  public string FirstName { get; set; }
  public string LastName { get; set; }
 }

Dapper中的擴(kuò)展方法Query()能夠讓你從數(shù)據(jù)庫中檢索數(shù)據(jù)并填充到對象模型中。

下面的方法是從Author表中檢索所有記錄,并存儲(chǔ)到內(nèi)存中,最后返回一個(gè)集合:

public List<Author> ReadAll()
  {
   using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["AdventureWorks"].ConnectionString))
   {
    return db.Query<Author>
    ("Select * From Author").ToList();
   }
  }

注意需要在程序中包含Dapper命名空間,才能使用Dapper:

using Dapper;

下面的方法演示了如何從Auhor表中檢索特定的一條記錄:

public Author Find(int id)
  {
   using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["AdventureWorks"].ConnectionString))
   {
    return db.Query<Author>("Select * From Author WHERE Id = @Id", new { id }).SingleOrDefault();
   }
  }

Dapper中的Execute()方法可以用于向數(shù)據(jù)庫中插入,更新,刪除數(shù)據(jù)。這個(gè)方法會(huì)返回一個(gè)整數(shù),表示在執(zhí)行查詢時(shí)受到影響的行數(shù)。

下面的方法演示了如何用Dapper更新一條記錄:

public int Update(Author author)
  {
   using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["AdventureWorks"].ConnectionString))
   {
    string sqlQuery = "UPDATE Author SET FirstName = @FirstName, " +
    " LastName = @LastName “ + “WHERE Id = @Id";
    int rowsAffected = db.Execute(sqlQuery, author);
    return rowsAffected;
   }
  }

正如以上代碼所看到的,Update()方法返回受影響的行數(shù),也就是已更新的記錄數(shù),在本例中只會(huì)更新一條記錄,所以方法成功時(shí)將會(huì)返回1.

存儲(chǔ)過程在Dapper中的使用:

要使用Dapper處理存儲(chǔ)過程,需在調(diào)用Query()或者Exectue()方法時(shí)顯示地提到命令類型。下面的示例演示了如何使用Dapper來處理存儲(chǔ)過程:

public List<Author> Read()
  {
   using (IDbConnection db = new SqlConnection(ConfigurationManager.ConnectionStrings["AdventureWorks"].ConnectionString))
   {
    string readSp = "GetAllAuthors";
    return db.Query<Author>(readSp, commandType: CommandType.StoredProcedure).ToList();
   }
  }

Dapper也支持事務(wù),例如,如果需要我們可以使用事務(wù)操作,為此,你可以利用BeginTransaction() and EndTransaction()方法,就像通常在ADO.NET中處理事務(wù)一樣,然后,您需要在BeginTransaction()和EndTransaction()方法調(diào)用中編寫事務(wù)語句。

Dapper非常輕且使用起來非常簡單,它不會(huì)為你生成SQL,但是可以很容易地將查詢結(jié)果映射到POCOs(普通的舊CLR對象).最重要的是,你可以獲得比EntityFrameWork更快的執(zhí)行速度,事實(shí)上,幾乎和ADO.NET一樣。

這是我翻譯的國外的一篇文章,旨在提升自己的英語水平,以及加深自己對知識(shí)點(diǎn)的積累,如果能幫助到一些小伙伴那就再好不過了。

原文鏈接:

https://www.infoworld.com/article/3025784/application-development/how-to-work-with-dapper-in-c.html

總結(jié)

以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關(guān)文章

  • C# 設(shè)置系統(tǒng)日期格式的方法

    C# 設(shè)置系統(tǒng)日期格式的方法

    公司電腦各式各樣的都有,里面的設(shè)置也有很多不統(tǒng)一的,我們做軟件一般會(huì)從系統(tǒng)中獲取一些數(shù)據(jù),比如日期時(shí)間,環(huán)境變量的路徑參數(shù),可以用批處理文件達(dá)到我們所想要的目的,也可以用C#代碼
    2013-03-03
  • c# Invoke和BeginInvoke 區(qū)別分析

    c# Invoke和BeginInvoke 區(qū)別分析

    這篇文章主要介紹了c# Invoke和BeginInvoke 區(qū)別分析,需要的朋友可以參考下
    2014-10-10
  • DevExpress之TreeList用法實(shí)例總結(jié)

    DevExpress之TreeList用法實(shí)例總結(jié)

    這篇文章主要介紹了DevExpress之TreeList用法,對于C#初學(xué)者有一定的借鑒價(jià)值,需要的朋友可以參考下
    2014-08-08
  • 基于C#委托的深入分析

    基于C#委托的深入分析

    本篇文章介紹了,基于C#委托的深入分析。需要的朋友參考下
    2013-04-04
  • C#如何調(diào)用MFC 窗口 DLL

    C#如何調(diào)用MFC 窗口 DLL

    這篇文章主要介紹了C#如何調(diào)用MFC 窗口 DLL,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • C# Mqtt 斷線重連的實(shí)現(xiàn)代碼

    C# Mqtt 斷線重連的實(shí)現(xiàn)代碼

    這篇文章主要介紹了C# Mqtt 斷線重連,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-09-09
  • C#詞法分析器之構(gòu)造NFA詳解

    C#詞法分析器之構(gòu)造NFA詳解

    本篇文章介紹了,C#詞法分析器之構(gòu)造NFA詳解。需要的朋友參考下
    2013-05-05
  • C#查詢SqlServer數(shù)據(jù)庫并返回單個(gè)值的方法

    C#查詢SqlServer數(shù)據(jù)庫并返回單個(gè)值的方法

    這篇文章主要介紹了C#查詢SqlServer數(shù)據(jù)庫并返回單個(gè)值的方法,涉及C#操作SQLServer數(shù)據(jù)庫查詢的相關(guān)技巧,需要的朋友可以參考下
    2015-06-06
  • C#正則表達(dá)式Regex類的常用匹配

    C#正則表達(dá)式Regex類的常用匹配

    本文通過幾個(gè)具體的實(shí)例,給大家詳細(xì)介紹了C#中的正則表達(dá)式Regex類的實(shí)用方法,非常的細(xì)致,有需要的小伙伴可以參考下
    2015-12-12
  • WPF TextBox水印效果制作方法詳解

    WPF TextBox水印效果制作方法詳解

    這篇文章主要為大家詳細(xì)介紹了WPF TextBox水印效果的制作方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-09-09

最新評論