ASP.NET Core 1.0 使用 Dapper 操作 MySql(包含事務)

来源:http://www.cnblogs.com/xishuai/archive/2016/12/02/aspnet-core1-dapper-mysql-transaction.html
-Advertisement-
Play Games

操作 MySql 資料庫使用 程式包(MySql 開發,其他第三方可能會有些問題)。 project.json 代碼: 測試資料庫腳本: sql CREATE TABLE ( int(11) NOT NULL AUTO_INCREMENT, varchar(255) DEFAULT NULL, in ...


操作 MySql 資料庫使用MySql.Data程式包(MySql 開發,其他第三方可能會有些問題)。

project.json 代碼:

{
  "version": "1.0.0-*",
  "buildOptions": {
    "emitEntryPoint": true
  },

  "dependencies": {
    "Microsoft.NETCore.App": {
      "type": "platform",
      "version": "1.0.1"
    },
    "Dapper": "1.50.2",
    "MySql.Data": "7.0.6-IR31"
  },

  "frameworks": {
    "netcoreapp1.0": {
      "imports": "dnxcore50"
    }
  }
}

測試資料庫腳本:

CREATE TABLE `products` (
  `ProductID` int(11) NOT NULL AUTO_INCREMENT,
  `Name` varchar(255) DEFAULT NULL,
  `Quantity` int(11) DEFAULT NULL,
  `Price` int(11) DEFAULT NULL,
  PRIMARY KEY (`ProductID`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=gbk;

Product 代碼:

public class Product
{
    [Key]
    public int ProductId { get; set; }
    public string Name { get; set; }
    public int Quantity { get; set; }
    public double Price { get; set; }
}

ProductRepository 代碼(數據訪問操作):

public class ProductRepository
{
    private string connectionString;
    public ProductRepository()
    {
        connectionString = @"server=localhost;database=dapperdemo;uid=root;pwd=123456;";
    }

    public IDbConnection Connection
    {
        get
        {
            return new MySqlConnection(connectionString);
        }
    }

    public void Add(Product prod)
    {
        using (IDbConnection dbConnection = Connection)
        {
            string sQuery = "INSERT INTO Products (Name, Quantity, Price)"
                            + " VALUES(@Name, @Quantity, @Price)";
            dbConnection.Open();
            dbConnection.Execute(sQuery, prod);
        }
    }

    public IEnumerable<Product> GetAll()
    {
        using (IDbConnection dbConnection = Connection)
        {
            dbConnection.Open();
            return dbConnection.Query<Product>("SELECT * FROM Products");
        }
    }

    public Product GetByID(int id)
    {
        using (IDbConnection dbConnection = Connection)
        {
            string sQuery = "SELECT * FROM Products"
                           + " WHERE ProductId = @Id";
            dbConnection.Open();
            return dbConnection.Query<Product>(sQuery, new { Id = id }).FirstOrDefault();
        }
    }

    public void Delete(int id)
    {
        using (IDbConnection dbConnection = Connection)
        {
            string sQuery = "DELETE FROM Products"
                         + " WHERE ProductId = @Id";
            dbConnection.Open();
            dbConnection.Execute(sQuery, new { Id = id });
        }
    }

    public void Update(Product prod)
    {
        using (IDbConnection dbConnection = Connection)
        {
            string sQuery = "UPDATE Products SET Name = @Name,"
                           + " Quantity = @Quantity, Price= @Price"
                           + " WHERE ProductId = @ProductId";
            dbConnection.Open();
            dbConnection.Execute(sQuery, prod);
        }
    }

    public void TransactionTest()
    {
        using (IDbConnection dbConnection = Connection)
        {
            string sQuery = "UPDATE Products SET Name = 'xishuai222'"
                           + " WHERE ProductId = 1";
            dbConnection.Open();
            using (var transaction = dbConnection.BeginTransaction())
            {
                dbConnection.Execute(sQuery);
                ///to do throw exception
                transaction.Commit();
            }
        }
    }
}

調用代碼:

public class Program
{
    public static void Main(string[] args)
    {
        var productRepository = new ProductRepository();
        var product = new Product() { Name = "xishuai" };
        productRepository.Add(product);

        var products = productRepository.GetAll();
        foreach (var item in products)
        {
            Console.WriteLine($"id: {item.ProductId}; name: {item.Name}");
        }

        productRepository.TransactionTest();

        Console.ReadKey();
    }
}

參考資料:


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

-Advertisement-
Play Games
更多相關文章
  • 其實任何資料裡面的任何知識點都無所謂,都是不重要的,重要的是學習方法,自行摸索的過程(不妥之處歡迎指正) 彙總:http://www.cnblogs.com/dunitian/p/4822808.html#mvc 本章Demo:https://github.com/dunitian/LoTCodeB ...
  • 電子樞紐全稱國家交通運輸物流公共信息平臺,主要提供物流及生產企業進行物流相關數據交換的標準和API。信用中心是電子樞紐眾多數據服務中的一個,提供物流參與者信用信息的上傳和查詢,包括運輸車輛、從業人員等。官方的示例和介紹大多以Java為主,.net的非常少,希望本文可以幫助.net開發人員快速掌握數據... ...
  • 需求:OAuth2實現第三方網站授權並獲取其相關數據來實現登錄等功能 暫時支持Facebook ,LinkedIn ,基本大同小異,只是返回時的數據不同,需根據具體返回類型進行相應處理 1.OAuth2認證流程 OAuth2認證協議涉及3方(應用、用戶和服務方),加之流程較為繁瑣,實現命名不盡相同, ...
  • ADO.NET是.NET中一組用於和數據源進行交互的面向對象類庫,提供了數據訪問的高層介面。 ADO.NOT類庫在System.Data命名空間內,根據我們訪問的不同資料庫選擇命名空間,System.Data.SqlClient。 ADO.NET類最重要的優點是支持資料庫以斷開連接的方式工作。 AD ...
  • 有好幾年沒有用過EasyUI了,最近在外包做的一個項目中新增功能時,又用到了,本以為和按照以前那樣用就可以了,可當我真正用的時候,發現許多地方不一樣了,就連官網的文檔都更新了,最突出的就是不知道什麼時候起多了一個data-options屬性。 記得,在過去一直都是用js直接調用的,現在突然變成dat ...
  • 第一次寫技術博文,記錄下工作中遇到的問題,給自己的知識做個備份,也希望能幫助到其他的同學 最近接手了公司的一個新的項目。有個頁面涉及相關設計。 分享一個經常用到的吧。 方法一: 直入主題吧 我們的目的是把 Enum類型裡面的 Enum: 實現效果: 拓展類: Attribute 類 Controll ...
  • 轉載自 歡大少的博客 一、AOP(面向切麵編程)簡介 在我們平時的開發中,我們一般都是面對對象編程,面向對象的特點是繼承、多態和封裝,我們的業務邏輯代碼主要是寫在這一個個的類中,但我們在實現業務的同時,難免也到多個重覆的操作行為,AOP就是將這些重覆的操作提取出來,運用動態代理,實現程式功能的統一維 ...
  • 如標題所言,是做刪除ListView綁定項的功能的;鑒於這個功能當時確實花費了很多時間,並且網上也找不到刪除所需的案例,所以,我就做了一份案例,僅供各位前輩和同行進行參考,如有不當之處,還望指點,我將再接再勵,下麵進入正題: 按照需求我們是需要實現的功能:點擊刪除的時候,把整個Items給移除,最初 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...