时间:2021-07-01 10:21:17 帮助过:26人阅读
private static SqlConnection Cnn = new SqlConnection(DbConfig.ConnectionString);
#region 判读SqlConnection 是否开启连接 并开启
/// <summary>
/// 判读SqlConnection 是否开启连接 并开启
/// </summary>
/// <returns>返回SqlConnection</returns>
private static SqlConnection GetCnn()
{
if (Cnn.State == ConnectionState.Closed)
{
Cnn.Open();
}
return Cnn;
}
#endregion
#region 关闭数据库连接
/// <summary>
/// 关闭数据库连接
/// </summary>
public static void CloseCnn()
{
Cnn.Close();
}
#endregion
#region 产生一个事务并开始
/// <summary>
/// 产生一个事务并开始
/// </summary>
/// <returns>返回此事务</returns>
public static SqlTransaction BeginTransaction()
{
SqlTransaction tran = GetCnn().BeginTransaction();
return tran;
}
#endregion
DAL:
代码如下:
public bool test(int i,SqlTransaction tran)
{
string sql = "insert into [test]([item]) values(@i)";
SqlParameter[] paras=new SqlParameter[]{new SqlParameter("@i",i)};
return sqlhelper.ExecutenQuery(sql, paras, CommandType.Text, tran)>0;
}
BLL:
代码如下:
UserDAO userdao = new UserDAO();
public bool test()
{
using (SqlTransaction tran = SQLHelper.BeginTransaction())
{
try
{
userdao.test(2, tran);
userdao.test(3, tran);
tran.Commit(); return true;
}
catch
{
tran.Rollback();
return false;
}
finally
{
SQLHelper.CloseCnn();//关闭数据库连接
}
}
}
上述代码在此次测试中通过,若要用于真实项目中,请修改后再使用,还有本人水平一般,写的不到之处请大家见谅。欢迎大家指导指正。