zoukankan      html  css  js  c++  java
  • C#中开启事务

    在C#中开启事务的步骤

    01.调用SqlConnection对象的BeginTransaction()方法,创建一个SqlTransaction对象,标志事务开始。

    02.将创建的SqlTransaction对象分配给要执行的SqlCommand的Transaction属性。

    03.调用相应的方法执行SqlCommand命令。

    04.调用SqlTransaction的Commit()方法完成事务。或调用Rollback()方法终止事务。  

    4.在进行事务操作中的注意点

    01.在调用BeginTransaction()方法开始事务之前,要打开数据库连接,否则出现异常。

    02.如果在事务的Commit()方法或RollBack()方法执行前数据库连接断开或关闭,则事务将回滚。

    //准备连接字符串
                string str = "data source=.;initial catalog=Myschool;uid=sa;pwd=123";
                //创建数据库连接对象
                SqlConnection con = new SqlConnection(str);
                //sql语句:添加一条记录到年级表
                string sql = "insert into grade values(@gradename)";
                //创建SqlParameter对象,设置参数
                SqlParameter sp = new SqlParameter("@gradename", txtgradename.Text);
                //创建命令对象
                 SqlCommand cmd = new SqlCommand(sql, con);
                 //通过Parameter集合的add()方法天填充参数集合
                 cmd.Parameters.Add(sp);
                //打开连接
                 con.Open();
                //默认让SqlTransaction对象为空
                 SqlTransaction trans = null;
                //开启事务:标志事务的开始
                 trans = con.BeginTransaction();
                try
                {
                    //将创建的SqlTransaction对象分配给要执行的sqlCommand的Transaction属性
                    cmd.Transaction = trans;
                    //执行sql如果添加成功放回1
                    int count=cmd.ExecuteNonQuery();
                    if (count > 0)
                    {
                        MessageBox.Show("成功");
                        //事务提交
                        trans.Commit();
                    }
                    else 
                    {
                        MessageBox.Show("失败");
                        //事务回滚
                        trans.Rollback();
                    }
                }
                catch (Exception)
                {
                    //如果某个环节出现问题,则将整个事务回滚
                    trans.Rollback();
                }

    出处:https://www.cnblogs.com/jiuyueBlog/p/9109860.html
  • 相关阅读:
    swiper-wrapper轮滑组件(多组轮滑界面)间隔无效问题
    jquery .play()报错is not a function
    html 表单input disabled属性提交后台无法获得数据
    git报错:Auto Merge Failed; Fix Conflicts and Then Commit
    js 获取转换网址中文参数
    day36 作业
    day38 并发编程(理论)
    day35 作业
    day36 解决粘包问题
    day35 socket套接字介绍
  • 原文地址:https://www.cnblogs.com/viruscih/p/10251192.html
Copyright © 2011-2022 走看看