zoukankan      html  css  js  c++  java
  • Dapper连接与事务的简单封装

    增删改查方面,已经有Dapper.Extension这么强大的工具了,我也实在没啥好写的,就随手写了个看起来比较优雅的连接与事务的封装。在之后使用Dapper.Extension类库时,完全可以照搬进去。

    using System;
    using System.Collections.Generic;
    using System.Data;
    using System.Data.SqlClient;
    using System.Linq;
    using Dapper;
    using DapperDemo.Models;
    
    namespace DapperDemo
    {
        internal class Program
        {
            public static string ConnString = "Server=(localdb)\MSSQLLocalDB;Database=DapperDB;";
    
            private static void Main(string[] args)
            {
                BuckInsert();
                BuckInsert();
                BuckInsert();
                DeleteAfterUpdating();
                GetPersonList().ForEach(c=>Console.WriteLine(c.UserName));
            }
    
            public static List<Person> GetPersonList()
            {
                var people = new List<Person>();
    
                ExecuteWithoutTransaction(conn =>
                {
                    people = conn.Query<Person>("select * from Person where id>@id", new {id = 2}).ToList();
                });
    
                return people;
            }
    
            public static bool BuckInsert()
            {
                return ExecuteWithTransaction((conn, trans) =>
                {
                    var r = conn.Execute(
                        @"insert Person(username, password,age,registerDate,address) values (@a, @b,@c,@d,@e)",
                        new[]
                        {
                            new {a = 1, b = 1, c = 1, d = DateTime.Now, e = 1},
                            new {a = 2, b = 2, c = 2, d = DateTime.Now, e = 2},
                            new {a = 3, b = 3, c = 3, d = DateTime.Now, e = 3}
                        },trans);
    
                    return r;
                });
            }
    
            public static bool Update()
            {
                return ExecuteWithTransaction((conn, trans) =>
                {
                    var r = conn.Execute(@"update Person set password='www.lanhuseo.com' where username=@username",
                        new {username = 2}, trans);
    
                    return r;
                });
            }
    
            public static bool Delete()
            {
                return ExecuteWithTransaction((conn, trans) =>
                {
                    var r = conn.Execute(@"delete from Person where id=@id", new {id = 1009}, trans);
    
                    return r;
                });
            }
    
            public static bool DeleteAfterUpdating()
            {
                return ExecuteWithTransaction((conn, trans) =>
                {
                    var r = conn.Execute(@"update Person set password='www.lanhuseo.com' where id=@id", new {id = 1009}, trans,
                        null, null);
                    r += conn.Execute("delete from Person where id=@id", new {id = 1010}, trans, null, null);
    
                    return r;
                });
            }
    
            /// <summary>
            ///     Used for query
            /// </summary>
            /// <param name="action"></param>
            public static void ExecuteWithoutTransaction(Action<SqlConnection> action)
            {
                UseConnectObj(action);
            }
    
            /// <summary>
            ///     Used for cud
            /// </summary>
            /// <returns>Execute Result</returns>
            /// <param name="func"></param>
            public static bool ExecuteWithTransaction(Func<SqlConnection, IDbTransaction, int> func)
            {
                var r = 0;
    
                UseConnectObj(conn =>
                {
                    IDbTransaction trans = conn.BeginTransaction();
    
                    r = func(conn, trans);
    
                    trans.Commit();
                });
    
                return r > 0;
            }
    
            /// <summary>
            ///     Use Action Connection
            /// </summary>
            /// <param name="action"></param>
            public static void UseConnectObj(Action<SqlConnection> action)
            {
                using (var conn = new SqlConnection(ConnString))
                {
                    conn.Open();
                    action(conn);
                }
            }
        }
    }
    
    
  • 相关阅读:
    用R语言中的神经网络预测时间序列:多层感知器和极限学习机
    R语言SIR模型(Susceptible Infected Recovered Model)代码sir模型实例
    confirmit中 domainValues() 方法
    confirmit中indexOf()方法
    confitmit中none()方法
    confirmit中any()方法参数问题
    confirmit中方法调用的数组之sort()区别
    confirmit平台问题汇总
    confirmit中创建的 if 判断条件的区别
    专业名称解释笔记
  • 原文地址:https://www.cnblogs.com/Wddpct/p/6885817.html
Copyright © 2011-2022 走看看