交易未被尊重具有多个查询的MySql .NET连接器

时间:2013-05-02 13:52:27

标签: c# mysql .net mysql-connector

我已经尝试过研究这个话题但是没有意义。我有一些代码试图执行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();
}
}

思想?

2 个答案:

答案 0 :(得分:2)

两个想法;首先:

  

在MySQL中,只有InnoDB和BDB(BerkeleyDB)表格格式支持事务。其他标准存储引擎忽略事务,无法回滚数据修改。

那么......您使用的是哪种表格格式?

其次:您可以尝试使用接受IsolationLevel的重载,只是为了明确 - 但我怀疑表格格式是真正的问题。

答案 1 :(得分:0)

也许这可以帮助别人。

连接器的某些旧版本(我认为大约6.4.4)会在查询错误后自动回滚事务。最新版本(6.9.6)似乎并非如此。

有趣的是,它似乎在某一点上起作用,但又停止了”让我感到奇怪。