在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如果添加成功
int count = cmd.ExecuteNonQuery();
if (count >= 0)
{
MessageBox.Show("成功");
//事务提交
trans.Commit();
}
else
{
MessageBox.Show("失败");
//事务回滚
trans.Rollback();
}
}
catch (Exception)
{
//如果某个环节出现问题,则将整个事务回滚
trans.Rollback();
}
使用事务一次处理多条SQL语句的方法,包括SQL中事务的写法以及调用的方法
执行一个操作时,要同时修改多张表里的数据,并且每条数据都必须操作成功,才算执行成功,为了防止有些数据操作失败,有些成功,而造成的数据错乱,我们要使用事务。
事务就是:只有所有操作都成功则成功,只要有一条数据操作失败,则回滚。
/// <summary>
/// 执行多条SQL语句,实现数据库事务。
/// </summary>sql2000数据库
/// <param name="SQLStringList">多条SQL语句</param>
public static void ExecuteSqlTran(List<string> SQLStringList)
{
using (SqlConnection conn = new SqlConnection(SqlHelper.ConString))
{
conn.Open();
SqlCommand cmd = new SqlCommand();
cmd.Connection = conn;
SqlTransaction tx = conn.BeginTransaction();
cmd.Transaction = tx;
bool isSucss = true;
try
{
for (int n = 0; n < SQLStringList.Count; n++)
{
string strsql = SQLStringList[n].ToString();
if (strsql.Trim().Length > 1)
{
cmd.CommandText = strsql;
cmd.ExecuteNonQuery();
}
}
}
catch (System.Data.SqlClient.SqlException E)
{
isSucss = false;
tx.Rollback();
throw new Exception(E.Message);
}
finally
{
if(isSucss )
{
tx.Commit();
}
}
}
}
private void button1_Click(object sender, EventArgs e)
{
try
{
//写SQL语句
List<string> SQLStringList = new List<string>();
string clickSql = "insert into [user] (name,age) values ('小名 ','4岁')";
string userSql = "update [class] set [name]='幼儿园' where id=2";
SQLStringList.Add(clickSql);
SQLStringList.Add(userSql);
ExecuteSqlTran(SQLStringList);
}
catch (Exception ex)
{
MessageBox.Show("操作失败!" + ex.Message); //输出
}
}