代碼:此SqlTransaction已完成;它不再可用,爲什麼?
我試圖運行這個功能,但它拋出錯誤: 此的SqlTransaction已完成;它不再可用。
我已經使用其他方式,但不工作。我用它沒有USING
但仍然是相同的錯誤。
爲什麼?
public Boolean AddWorkProgress(int WorkID, int ContractorID, float PhysicalProgress,
decimal FinancialProgress, int UserID, int OrgID, float FinancialProgressPecentage)
{
SqlCommand SqlCom = new SqlCommand("AddWorkProgress", DataBaseConnection.OpenConnection());
SqlCom.CommandType = CommandType.StoredProcedure;
using (SqlTransaction sqlTrans = SqlCom.Connection.BeginTransaction())
{
SqlCom.Transaction = sqlTrans;
try
{
SqlCom.Parameters.AddWithValue("@Work_ID", WorkID);
SqlCom.Parameters.AddWithValue("@Contractor_ID", ContractorID);
SqlCom.Parameters.AddWithValue("@PhysicalProgress", PhysicalProgress);
SqlCom.Parameters.AddWithValue("@FinancialProgress", FinancialProgress);
SqlCom.Parameters.AddWithValue("@OrgID", OrgID);
SqlCom.Parameters.AddWithValue("@fk_WebUsers_UserID", UserID);
SqlCom.Parameters.AddWithValue("@FinancialProgressPercentage", FinancialProgressPecentage);
SqlParameter SqlParamReturnStatus = new SqlParameter("@ReturnStatus", SqlDbType.Bit);
SqlCom.Parameters.Add(SqlParamReturnStatus);
SqlParamReturnStatus.Direction = ParameterDirection.Output;
SqlParameter SqlParamReturnStatusMessage = new SqlParameter("@ReturnStatusMessage", SqlDbType.VarChar, -1);
SqlCom.Parameters.Add(SqlParamReturnStatusMessage);
SqlParamReturnStatusMessage.Direction = ParameterDirection.Output;
SqlCom.ExecuteNonQuery();
DataBaseConnection.CloseConnection();
string ReturnStatusMessage = Convert.ToString(SqlParamReturnStatusMessage);
Boolean ReturnStatus = Convert.ToBoolean(SqlParamReturnStatus.Value);
// ProgressID = Convert.ToInt64(SqlParamReturnProgressID.Value);
sqlTrans.Commit();
return ReturnStatus;
}
catch (Exception ex)
{
sqlTrans.Rollback();
sqlTrans.Dispose();
throw ex;
}
}
}
看起來像你對我關閉連接您提交事務之前 –
或許你也應該投入'使用您的連接'塊也是如此。 – David
catch塊也是多餘的。 '使用'塊將回滾*和*處置交易。 –