Asp.net 在三层架构中事务的使用实例代码
Asp.net 在三层架构中事务的使用实例代码
发布时间:2016-12-29 来源:查字典编辑
摘要:接触3层也有一段时间了,了解水平一般,前段时间在想在三层中怎么使用事务呢,放在哪呢?Sqlherper?DAL?BLL?。然后我就疯狂的百度...

接触3层也有一段时间了,了解水平一般,前段时间在想在三层中怎么使用事务呢,放在哪呢?Sqlherper ? DAL? BLL?。然后我就疯狂的百度,好几次都是未果(因为做的都是小项目,不用事务也关系不大),今天我再次查时,好好的看了csdn上的以讨论,http://topic.csdn.net/u/20091101/19/f21697d7-8f0c-4eb3-8e59-d0fe2f0b04b0.html,结合前辈和高手们的意见,自己改了一个出来。我的想法是将事务逻辑写在业务逻辑层,数据库的处理还都是在SQLHELPER,BLL层通过事务SqlTransaction传值访问DAL,再访问Sqlhelper。接下来是分块的代码。

Sqlhelper:

复制代码 代码如下:

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();//关闭数据库连接

}

}

}

上述代码在此次测试中通过,若要用于真实项目中,请修改后再使用,还有本人水平一般,写的不到之处请大家见谅。欢迎大家指导指正。

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新asp.net教程学习
热门asp.net教程学习
编程开发子分类