“SqlTransaction 已完成;它再也无法使用”解决方法

“SqlTransaction 已完成;它再也无法使用”解决方法 当只是使用一次事务时,只用简单的事务就可以了示例代码:      SqlServerDataBaseobj=newSqlServerDataBase();       SqlConnectionconn=obj.DBconn();       conn.Open();       SqlTransactionmyTrans;       myTrans=co

大家好,又见面了,我是你们的朋友全栈君。 当只是使用一次事务时,只用简单的事务就可以了

示例代码:

       SqlServerDataBase obj = new SqlServerDataBase();
        SqlConnection conn = obj.DBconn();
        conn.Open();
        SqlTransaction myTrans;
        myTrans = conn.BeginTransaction(IsolationLevel.ReadCommitted);

        try
        {

            obj.Insert(“insert into StuInfo (StuNumber,Name,Sex,Specialty) values(‘” + stuNumber + “‘,'” + name + “‘,'” + sex + “‘,'” + specialty + “‘)”, null);
            obj.Insert(“insert into StuSkill(StuNumber,Skill) values(‘” + stuNumber + “‘,'” + skill + “‘)”, null);
            myTrans.Commit();
            Response.Write(“两条数据均插入到数据库中!”);
        }
        catch (Exception ex)
        {

            try
            {

                myTrans.Rollback();
            }
            catch (SqlException sqlEx)
            {

                if (obj.DBconn() != null)
                {

                    Response.Write(sqlEx.GetType()+”数据库打开失败”);
                    Response.Redirect(“submit.htm”);
                }
            }
        }
        finally
        {

            obj.DBconn().Close();
        }

  但是设计多个事务处理,比方使用for循环时,处理不当就会产生“SqlTransaction 已完成;它再也无法使用”的问题,主要就是因为SqlTransaction 使用了Commit()后就是不能在使用了,必须重新BeginTransaction()一个。

 批处理事务不应该把transaction事务放在for循环里,造成多个事务,这将导致错误.
应该把for放在transaction里,当成一个事务来处理,进行批处理

示例代码:

protected void btnDelete_Click(object sender, EventArgs e)  //删除
    {

        SqlServerDataBase del = new SqlServerDataBase();
        string str = “”;
        SqlConnection conn = del.DBconn();
        conn.Open();
        SqlTransaction myTrans;
        myTrans = conn.BeginTransaction(IsolationLevel.ReadCommitted);

        ListBox1.Items.Clear();
        try
        {

            for (int i = 0; i < GridView1.Rows.Count; i++)  //从GridView中选中checkbox
            {

                GridViewRow row = GridView1.Rows[i];
                bool isChecked = ((CheckBox)row.FindControl(“chkSelect”)).Checked;
                if (isChecked)
                {

                    ListBox1.Items.Add(GridView1.Rows[i].Cells[2].Text);
                    //Column 1 is the StuNumber column
                    str = GridView1.Rows[i].Cells[1].Text;  //获取删除行的StuNumber的值
                    // Response.Write(str.ToString());  
                    del.Delete(“delete from StuInfo where StuNumber = ‘” + str + “‘”, null);
                    del.Delete(“delete from StuSkill where StuNumber = ‘” + str + “‘”, null);//删除
                }

            }
            myTrans.Commit();
         }
        catch (Exception ex)
        {

            try
            {

                myTrans.Rollback();
            }
            catch (SqlException sqlEx)
            {

                if (del.DBconn() != null)
                {

                    Response.Write(sqlEx.GetType() + “数据库打开失败”);
                    Response.Redirect(“submit.htm”);
                }
            }
        }
        finally
        {

            conn.Close();
        }
        BindData();
    }
}

注意:两者在使用上是有区别的!

另外在windows服务中,

windows的服务服务正常运行一段时间后,在ontimer中就无法再启动了,提示:此SqlTransaction已完成;它再也无法使用。
有可能是 timer 时间间隔 太短,造成事务太频繁!
也可能是Transaction两次提交的原因,需要注意一下timer的启用时机。

参考网站:

 C#事务的使用、示例及注意事项

http://blog.csdn.net/kiki113/archive/2007/04/29/1591999.aspx 

http://topic.csdn.net/u/20070830/10/62719c5d-cb7a-47e5-87a3-89077d82dc77.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/143857.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 十大排序——最全最详细,一文让你彻底搞懂

    十大排序——最全最详细,一文让你彻底搞懂最全最详细,一文带你了解十大排序Sort写在前面因为GitHub的主文档太长,不容易维护,所以建立子文档以辅助。本篇内容是主文档中的排序部分的扩展。注:本篇内容最早发布于GitHub中,如果你觉得我写得还行,记得给我Star或是Fork~~献给我的家人作者Three领英知乎力扣CSDN????????????不积跬步,无以至千里;不积小流,无以成江海。????Top代表返回顶部????代表到文档末尾如果你觉得我

    2022年7月24日
    17
  • 协同过滤推荐算法介绍(协同过滤的推荐算法)

    随着电商企业的发展,为了更好的了解用户喜好以便于将更加适合的商品推荐给用户,不仅能得到用户好的评价,而且也有利于自身企业的利益,因此,随之诞生了很多推荐系统,最为常用的推荐算法就是协同过滤算法。转载请标明原文链接推荐算法的基础就是基于两个对象之间的相关性,常用的计算方法有欧几里得相似性,这是一种使用较多的相似性计算方法。除此之外还有曼哈顿相似性和余弦相似性的计算方法。协同过滤算…

    2022年4月10日
    46
  • Vue+Element UI 商城后台管理系统[通俗易懂]

    Vue+Element UI 商城后台管理系统[通俗易懂]Vue+ElementUI商城后台管理系统一、前言1.项目背景此项目来自B站Vue实战项目:电商管理系统(Element-UI)。此项目的功能与后端提供的接口并不完全相同,根据后端接口进行开发并添加了部分功能从而进行修改。在完成此项目并测试上线后,在这里记录一下项目的开发思路,以及遇到的一些问题。自我感觉这个项目是一个很不错的关于Vue+ElementUI的练手项目2.部分效果图展示先放一些效果图项目上线地址:https://aerowang.cn/vue_shop

    2025年5月27日
    2
  • java写爬虫没python好吗_java爬虫代码

    java写爬虫没python好吗_java爬虫代码写在前面前段时间实习结束回来休息,某日闲逛无意间又打开了半次元,突然看见几个好漂亮的coser小姐姐,就想存个图片当壁纸(づ ̄3 ̄)づ╭❤~然而又发现,很多小姐姐都设置了作品禁止保存或者是右下角带水印身为一个重度强迫症患者,默默打开浏览器,看看能不能偷鸡扒到原图。。。开始之前1.所有图片都是各位作者付出辛苦劳动得来的,请尊重coser版权。2.图片自己下载使用可以,请勿用于商业用途,转载请先取…

    2022年9月14日
    4
  • RELU激活函数作用「建议收藏」

    RELU激活函数作用「建议收藏」梯度消失现象:在某些神经网络中,从后向前看,前面层梯度越来越小,后面的层比前面的层学习速率高。梯度消失原因:sigmoid函数导数图像导数最大为0.25&lt;1权重初始值通常使用一个高斯分布所以|w|&lt;1,所以wjσ′(zj)&lt;0.25,根据链式法则计算梯度越来越小。由于层数的增加,多个项相乘,势必就会导致不稳定的情况。sigmoid激活函数的…

    2022年6月16日
    34
  • SOAP 协议「建议收藏」

    SOAP 协议「建议收藏」参考链接SOAP教程http协议与soap协议之间的区别SOAPSOAP是基于XML的简易协议,可使应用程序在HTTP之上进行信息交换SOAP提供了一种标准的方法,使得运行在不同的操作系统并使用不同的技术和编程语言的应用程序可以互相进行通信SOAP协议可以简单地理解为:SOAP=RPC+HTTP+XML采用HTTP作为通信协议RPC(RemoteProcedureCallProtocol远程过程调用协议)作为一致性的调用途径XML作为数据传送的格式,从而允许服务提供

    2022年7月12日
    16

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号