我已经尝试过研究这个话题但是没有意义。我有一些代码试图执行UPDATE查询然后循环另一组INSERT查询。第二个查询错误,因为我省略了参数(这是故意引发错误)。 UPDATE仍然会被提交,即使它不应该......
这是代码....
using (MySqlConnection con = existingCon.Clone())
{
con.Open();
MySqlParameter paramTimeStamp;
MySqlParameter paramFileNo;
MySqlParameter paramDescription;
MySqlParameter paramComment;
MySqlParameter paramUserInfo;
MySqlParameter paramPaymentType;
MySqlParameter paramSeriesLink;
MySqlParameter paramOriginalSubmitDate;
using (MySqlTransaction transact = con.BeginTransaction())
{
try
{
using (
MySqlCommand cmd =
new MySqlCommand(
"UPDATE Payments "
+ "SET strStatus = 'processing-preupload' "
+ "WHERE strStatus = 'processing-prepost';",
con))
{
cmd.Transaction = transact;
cmd.ExecuteNonQuery();
}
}
catch (Exception e)
{
transact.Rollback();
throw;
}
foreach (Payment payment in payments)
{
try
{
using (
MySqlCommand cmd =
new MySqlCommand(
"INSERT INTO Activity "
+ "(dtmTimeStamp, strFileNumber, strDescription, strComment, "
+ "strUserInfo, strPaymentType, dtmSeriesLink, dtmOriginalSubmitDate) "
+ "VALUES (@paramTimeStamp, @paramFileNo, @paramDescription, @paramComment, "
+ "@paramUserInfo, @paramPaymentType, @paramSeriesLink, @paramOriginalSubmitDate);",
con))
{
paramTimeStamp = new MySqlParameter("@paramTimeStamp", DateTime.Now);
paramFileNo = new MySqlParameter("@paramFileNo", payment.strFileNumber);
paramDescription = new MySqlParameter("@paramDescription", description);
paramComment = new MySqlParameter("@paramComment", comment);
paramUserInfo = new MySqlParameter("@paramUserInfo", userInfo);
paramPaymentType = new MySqlParameter("@paramPaymentType", PAYMENT_TYPE);
paramSeriesLink = new MySqlParameter(
"@paramSeriesLink",
payment.strSeriesLink_corrected);
paramOriginalSubmitDate = new MySqlParameter(
"@paramOriginalSubmitDate",
payment.strSubmitDate_corrected);
cmd.Transaction = transact;
cmd.ExecuteNonQuery();
}
}
catch (Exception e)
{
transact.Rollback();
throw;
}
}
transact.Commit();
}
}
思想?
答案 0 :(得分:2)
两个想法;首先:
在MySQL中,只有InnoDB和BDB(BerkeleyDB)表格格式支持事务。其他标准存储引擎忽略事务,无法回滚数据修改。
那么......您使用的是哪种表格格式?
其次:您可以尝试使用接受IsolationLevel
的重载,只是为了明确 - 但我怀疑表格格式是真正的问题。
答案 1 :(得分:0)
也许这可以帮助别人。
连接器的某些旧版本(我认为大约6.4.4)会在查询错误后自动回滚事务。最新版本(6.9.6)似乎并非如此。
“有趣的是,它似乎在某一点上起作用,但又停止了”让我感到奇怪。