ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

mysql – zend adapter beginTransaction()和commit()失败

2019-07-23 19:14:31  阅读:279  来源: 互联网

标签:zend-db mysql transactions zend-framework referential-integrity


我面临一个奇怪的问题

Zend_DB_Adapter的beginTrasaction()和commit()方法似乎没有按预期工作.我在beginTrasaction()和commit()方法中包含INSERT语句(在FOR LOOP中).但即使出现如下所示的错误,我仍然会看到已经插入了一些行,而我还是希望在发生错误时不会发生提交.我无法理解为什么.有人可以帮忙吗谢谢.

SQLSTATE [23000]:完整性约束违规:1062键’PRIMARY’重复输入’0′

代码块如:

      **$localDB->beginTransaction();**
    try{
        echo $localDB->isConnected();

        $localDB->query("TRUNCATE TABLE $this->dbTable");
        **foreach ($rowSet as $row){**
            foreach ($row as $key=>$value){
                $localRow[$this->columnMap[$key]] =$value;
            }
            **$localDB->insert($this->dbTable,$localRow);**

        }

         $localDB->commit();
        }
        catch (Exception $e){
        $localDB->rollBack();
        echo $e->getMessage();
    }   

解决方法:

TRUNCATE TABLE将导致implicit commit将结束当前事务.

1)在beginTransaction()之前放置TRUNCATE TABLE.

$localDB->query("TRUNCATE TABLE $this->dbTable");
$localDB->beginTransaction();
try {
    ...

    $localDB->commit();
} catch (Exception $e){
    $localDB->rollBack();
    echo $e->getMessage();
} 

2)DELETE FROM应该是事务保存(but slower)

$localDB->beginTransaction();
try {
    $localDB->query("DELETE FROM $this->dbTable");
    ...

    $localDB->commit();
} catch (Exception $e){
    $localDB->rollBack();
    echo $e->getMessage();
} 

标签:zend-db,mysql,transactions,zend-framework,referential-integrity
来源: https://codeday.me/bug/20190723/1516131.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有