zoukankan      html  css  js  c++  java
  • .net中使用mysql回滚和sqlserver回滚的区别

    关于sqlserver事务和mysql事务

    首先这是一种方法 

    public static int GetExecteQuery()
            {
                SqlConnection conn = new SqlConnection(CONN_STRING);//在这里CONN_STRING也就是连接sqlserver数据库的语句
                conn.Open();//打开
                SqlCommand command = conn.CreateCommand();//在这里也可以写成SqlCommand command=new SqlCommand();

                SqlTransaction transaction = null;
                transaction = conn.BeginTransaction(); //这两句也可以写成  SqlTransaction transaction =new SqlTransaction();
                command.Connection = conn;              
                command.Transaction = transaction;
                int count = 0;

                try
                {
                    command.CommandText = "insert into company values('AA','AAAA','true','null')";
                    command.ExecuteNonQuery();
                    command.CommandText = "insert into company values('AA','AAAA','tru1e','null')";
                    count = command.ExecuteNonQuery();
                    transaction.Commit(); //进行执行
                }
                catch
                {

                    transaction.Rollback();//发生异常进行回滚
                }

                return count;
            }

              

               关于mysql

              MySqlCommand mySqlCmd = new MySqlCommand();
                MySqlConnection mySqlConn = new MySqlConnection(connStr);
                try
                {
                    if (mySqlConn != null && mySqlConn.State == System.Data.ConnectionState.Closed)
                    {
                        mySqlConn.Open();
                    }
                    mySqlCmd.Connection = mySqlConn;
                    mySqlCmd.Transaction = mySqlConn.BeginTransaction();
                    mySqlCmd.CommandType = System.Data.CommandType.Text;
                    for (int i = 0; i < sqls.Count; i++)
                    {
                        mySqlCmd.CommandText = sqls[i].ToString();
                        mySqlCmd.ExecuteNonQuery();
                    }
                    mySqlCmd.Transaction.Commit();
                    return true;
                }
                catch (Exception)
                {
                    mySqlCmd.Transaction.Rollback();
                    throw;
                }
                finally
                {
                    this.CloseConn();
                }                              

  • 相关阅读:
    BZOJ 2301 [HAOI2011]Problem b ——莫比乌斯反演
    VIJOS 1889 天真的因数分解 ——莫比乌斯函数
    BZOJ 2440 [中山市选2011]完全平方数 ——莫比乌斯函数
    BZOJ 3939 [Usaco2015 Feb]Cow Hopscotch ——线段树 CDQ分治
    UOJ 274 【清华集训2016】温暖会指引我们前行 ——Link-Cut Tree
    BZOJ 2246 [SDOI2011]迷宫探险 ——动态规划
    BZOJ 2037 [Sdoi2008]Sue的小球
    BZOJ 3227 [Sdoi2008]红黑树(tree) ——贪心 动态规划
    BZOJ 1974 [Sdoi2010]auction 代码拍卖会 ——动态规划
    sql注入
  • 原文地址:https://www.cnblogs.com/sdya/p/3937735.html
Copyright © 2011-2022 走看看