我们现在正在寻找问题的根源,但同时我们想重新启动服务器并让客户继续前进.
现在每次我们启动程序时它只是说“sqlConnection不支持并行事务”.我们没有改变程序,编译和客户服务器上的任何内容,但在“可能的死锁” – 情况后,它想要再次上线.
我们有7个运行程序的客户端(计算机),每个客户端正在与本地服务器上的Web服务进行通信,并且Web服务正在与sql-server(与Web服务器相同的机器)进行通信.
我们已经重新启动了sql-server和iis-server,但没有重新启动服务器,因为服务器上运行了其他重要的服务,所以我们做的最后一件事.
我们可以在管理选项卡中找不到锁或任何东西.
所以我的问题是,为什么“sqlConnection不支持并行事务”错误从一次传递到另一次而不改变程序中的任何内容,它仍然存在于sql-restart之间.
它似乎发生在程序启动时的第一个db-request处.
如果您需要更多信息,请询问.我很困惑……
更多信息:
我不认为我有“长期”运行交易.方案通常是我有一个20-100行(ContractRows)的数据集,其中Ill在tableAdapter上执行.Update.我还循环了那些20-100行,对于其中一些,我创建了ad-hook-sql-querys(例如,如果租用的产品被标记为返回,我创建一个sql-query来标记产品在数据库中返回)
所以我这样做非常简单:
Create objTransactionObject Create objtableadapter (objTransactionObject) for each row in contractDS.contractrows if row.isreturned then strsql &= "update product set instock=1 where prodid=" & row.productid & vbcrlf End if next objtableadapter.update(contractDS) objData.ExecuteQuery(strsql,objTransactionObject) if succsesfull objtransactionobject.commit else objtransactionobject.rollback end if objTran.Dispose()
然后我做提交或回滚取决于它是否进展顺利.
编辑:没有一个答案解决了问题,但我会感谢你拍摄指针的好麻烦.
“sqlConnection不支持并行事务”突然消失了,现在sql-server只是“每天下降”4-5次,我想这是一个僵局,但是我没有正确的知识发现并且很短现在可以为我监控的sql专家.我只是重新启动sql-server,一切都恢复正常. 10次中的1次我还要重新启动计算机.它真的很烦我(当然还有我的客户).
任何知道一个人在分析瑞典(或世界各地,英语)的死锁或其他sql问题的麻烦的人都可以自由地联系我.我知道这不是一个联系网站,但我带着我的问题,因为我已经用完了选项,我花了3天时间优化客户,以确保我们关闭连接并且不要做太多愚蠢的事情.没有运气.