我的网页编码结构如下:
SqlConnection conX =new SqlConnection(blablabla);
conX.Open();
SqlTransaction tran=conX.BeginTransaction();
try{
SqlCommand cmdInsert =new SqlCommand("INSERT INTO Table1(ColX,ColY) VALUES @x,@y",conX);
cmdInsert.Transaction=tran;
cmdInsert.ExecuteNonQuery();
SqlCommand cmdSelect=new SqlCOmmand("SELECT * FROM Table1",conX);
cmdSelect.Transaction=tran;
SqlDataReader dtr=cmdSelect.ExecuteReader();
//read stuff from dtr
dtr.Close();
cmdInsert=new SqlCommand("UPDATE Table2 set ColA=@a",conX);
cmdInsert.Transaction=tran;
cmdInsert.ExecuteNonQuery();
//display MiscMessage
tran.Commit();
//display SuccessMessage
}
catch(Exception x)
{
tran.Rollback();
//display x.Message
}
finally
{
conX.Close();
}
所以,在MiscMessage之前,一切似乎都有效。然后,过了一会儿(可能是15秒?)x.Message弹出,说:
“超时已过期。操作完成前经过的超时时间或服务器没有响应。”
我的trans.Commit()出了什么问题?数据库没有更新,所以我假设trans.Rollback工作...
我已经读过死锁会导致超时...这个问题是由我的SELECT语句从Table1中选择引起的,第一个INSERT语句正在使用它吗? 如果是这样,我该怎么办?如果那不是问题,那是什么?
答案 0 :(得分:0)
因为您显示MiscMessage,您的事务仍然打开,然后超时到期。提交事务,然后显示消息。