码:
我正在尝试运行此功能,但会引发错误:
此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;
}
}
}
最佳答案
您在提交事务之前要关闭连接:
DataBaseConnection.CloseConnection();
// skipped code
sqlTrans.Commit();
从MSDN开始:
如果提交和回滚都生成InvalidOperationException,则
连接被终止,或者如果事务已经被滚动
回到服务器上。
这正是您的情况-在事务提交/回滚之前连接已关闭。
关于c# - 此SqlTransaction已完成;它不再可用,为什么?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/42717423/