• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Asp.net 在三层架构中事务的使用实例代码
    接触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();//关闭数据库连接
    }
    }
    }

    上述代码在此次测试中通过,若要用于真实项目中,请修改后再使用,还有本人水平一般,写的不到之处请大家见谅。欢迎大家指导指正。
    您可能感兴趣的文章:
    • 如何使用AngularJs打造权限管理系统【简易型】
    • ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统之前端页面框架构建源码分享
    • ASP.NET实现学生管理系统
    • ASP.NET餐饮管理系统制作代码分享
    • ASP.NET网站管理系统退出 清除浏览器缓存,Session的代码
    • 2007 10.30动易网站管理系统vote.asp页面存在SQL注入漏洞
    • ssi框架学习总结(mvc三层架构)
    • ASP.NET创建三层架构图解详细教程
    • asp.net实现三层架构的例子
    • MVC+EasyUI+三层架构简单权限管理系统
    上一篇:一个Asp.Net的显示分页方法 附加实体转换和存储过程 带源码下载
    下一篇:asp.net 文件路径之获得虚拟目录的网站的根目录
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    Asp.net 在三层架构中事务的使用实例代码 Asp.net,在,三层,架构,中,