zoukankan      html  css  js  c++  java
  • C# 显式事务,隐式事务

    1.隐式事务(TransactionScope)

    超出事务范围时 如果没有手动调用Complete()方法,则不会提交事务

    string strConn = "server=.;uid=sa;pwd=123;database=db_test;";
                string strSql = "insert into user_info (name,tel) values ('ee',13590305258)";
    
    using (TransactionScope tran = new TransactionScope())
                {
                    using (SqlConnection conn = new SqlConnection(strConn))
                    {
                        conn.Open();
    
    
                        SqlCommand cmd = new SqlCommand(strSql, conn);
    
                        cmd.CommandType = CommandType.Text;
    
                        int result = cmd.ExecuteNonQuery();
    
                        if (result == 1)
                        {
                            Console.WriteLine("数据添加成功...");
                        }
    
    
                        conn.Close();
                    }
    
                    Console.WriteLine("请输入1或0  1提交事务;0回滚事务....");
    
                    int key = Convert.ToInt32(Console.ReadLine());
                    if (key == 0)
                    {
                        //回滚当前环境中正在运行的事务
                        //System.Transactions.Transaction.Current.Rollback();
                        Console.WriteLine("回滚事务完毕...");
                    }
                    else
                    {
                        tran.Complete();   //超出事务范围时 如果没有手动调用Complete()方法,则不会提交事务
                        Console.WriteLine("提交事务完毕...");
                    }
                }

     2.显式事务

    创建 CommittableTransaction 的实例并不会自动设置环境事务上下文。因此,资源管理器上的任何操作都不属于该事务。全局 Transaction 对象上的静态 Current 属性用于设置或检索环境事务,应用程序必须手动设置该属性,才能确保资源管理器可参与事务

    string strConn = "server=.;uid=sa;pwd=123;database=db_test;";
                string strSql = "insert into user_info (name,tel) values ('ee',13590305258)";
    
    CommittableTransaction tran = new CommittableTransaction();
                using (SqlConnection conn = new SqlConnection(strConn))
                {
                    conn.Open();
                    conn.EnlistTransaction(tran);   //需要把事务添加到当前环境中....
    
                    SqlCommand cmd = new SqlCommand(strSql, conn);
                    cmd.CommandType = CommandType.Text;
    
                    int result = cmd.ExecuteNonQuery();
                    if (result == 1)
                    {
                        Console.WriteLine("数据添加成功...");
                    }
    
                    conn.Close();
                }
    
    
                Console.WriteLine("请输入1或0  1提交事务;0回滚事务....");
                int key = Convert.ToInt32(Console.ReadLine());
                if (key == 0)
                {
                    tran.Rollback();
                    Console.WriteLine("回滚事务完毕...");
                }
                else
                {
                    tran.Commit();
                    Console.WriteLine("提交事务完毕...");
                }
  • 相关阅读:
    PL/SQL Developer 远程连接oracle数据库
    Python 类与对象 __init__()参数
    微信公众号--发送模板消息
    微信公众号--进入菜单之前获取用户信息
    微信公众号-自定义菜单
    Java--时间转换
    微信公众号--被动回复用户消息
    {"errcode":40017,"errmsg":"invalid button type hint: [I8nq_a0783sha1]"}
    在使用XStream时没有processAnnotations方法
    在idea的控制台中中文显示为乱码
  • 原文地址:https://www.cnblogs.com/szfhquan/p/2838906.html
Copyright © 2011-2022 走看看