一、事务的操作

11 篇文章 0 订阅

事务是指用户定义的一个数据库操作序列,这些操作要么全做要么全不做,它是一个不可分割的工作单位。一个事务可以是一条SQL语句,一组SQL语句,或整个程序。

public bool transactionOp()
{
    // 事务成功返回true,事务失败返回false
    bool result = false;
    string SqlConnectionString = "Data Source=.;Initial Catalog=DataBaseName;User ID=sa;pwd=123456;Connection Lifetime=0;max pool size=200";
    SqlConnection cn = new SqlConnection(SqlConnectionString);
    SqlCommand cmd = new SqlCommand();
    SqlTransaction transaction = null;
 
    try
    {
        // 打开数据库
        if (cn.State == ConnectionState.Closed)
        {
            cn.Open();
        }
 
        // 开始事务
        transaction = cn.BeginTransaction();
        cmd.Transaction = transaction;
        cmd.Connection = cn;
 
        // 执行第一条SQL语句
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "insert into Users values('admin', 'admin')";
        if (cmd.ExecuteNonQuery() < 0)
            throw new Exception();
 
        // 执行第二条SQL语句
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "update Users set pwd = '123456' where name = '小明'";
        if (cmd.ExecuteNonQuery() < 0)
            throw new Exception();
 
        // 提交事务
        transaction.Commit();
        result = true;
    }
    catch
    {
        result = false;
        // 回滚事务
        transaction.Rollback();
    }
    finally
    {
        // 关闭数据库
        if (cn.State == ConnectionState.Open)
        {
            cn.Close();
        }
        cn.Dispose();
        cmd.Dispose();
        transaction.Dispose();
    }
    return result;
}
public bool transactionOp()
{
    // 事务成功返回true,事务失败返回false
    bool result = false;
    string SqlConnectionString = "Provider = Microsoft.ACE.OLEDB.12.0;Data Source=.\\Data\\DataBaseName.accdb;Jet OLEDB:Database Password=123456";
    //string SqlConnectionString = "Provider = Microsoft.ACE.OLEDB.4.0;Data Source=.\\Data\\DataBaseName.accdb;Jet OLEDB:Database Password=123456";
    OleDbConnection cn = new OleDbConnection(SqlConnectionString);
    OleDbCommand cmd = new OleDbCommand();
    OleDbTransaction transaction = null;
 
    try
    {
        // 打开数据库
        if (cn.State == ConnectionState.Closed)
        {
            cn.Open();
        }
 
        // 开始事务
        transaction = cn.BeginTransaction();
        cmd.Transaction = transaction;
        cmd.Connection = cn;
 
        // 执行第一条SQL语句
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "insert into Users values('admin', 'admin')";
        if (cmd.ExecuteNonQuery() < 0)
            throw new Exception();
 
        // 执行第二条SQL语句
        cmd.CommandType = CommandType.Text;
        cmd.CommandText = "update Users set pwd = '123456' where name = '小明'";
        if (cmd.ExecuteNonQuery() < 0)
            throw new Exception();
 
        // 提交事务
        transaction.Commit();
        result = true;
    }
    catch
    {
        result = false;
        // 回滚事务
        transaction.Rollback();
    }
    finally
    {
        // 关闭数据库
        if (cn.State == ConnectionState.Open)
        {
            cn.Close();
        }
        cn.Dispose();
        cmd.Dispose();
        transaction.Dispose();
    }
    return result;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

努力吧少年-珊珊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值