首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > PHP >

Zend Framework 事务处理 有关问题

2013-01-02 
Zend Framework 事务处理 问题官方给出一个示例,如下:?php// 创建一个 $db对象, 然后开始做一个事务处理.

Zend Framework 事务处理 问题
官方给出一个示例,如下:

<?php

// 创建一个 $db对象, 然后开始做一个事务处理.
$db->beginTransaction();

// 尝试数据库操作.
// 假如成功,commit该操作;
// 假如, roll back.
try {
    $db->query(...);
    $db->commit();
} catch (Exception $e) {
    $db->rollBack();
    echo $e->getMessage();
}

?>


我写的实例中,确没有通过,而是提示
Fatal error: Uncaught exception 'PDOException' with message 'There is already an active transaction' in E:\php\ZendFramework\library\Zend\Db\Adapter\Pdo\Abstract.php:305 Stack trace: #0 E:\php\ZendFramework\library\Zend\Db\Adapter\Pdo\Abstract.php(305): PDO->beginTransaction() #1 E:\php\ZendFramework\library\Zend\Db\Adapter\Abstract.php(484): Zend_Db_Adapter_Pdo_Abstract->_beginTransaction() #2 D:\svnrepos\WiClub\src\application\models\shop.php(76): Zend_Db_Adapter_Abstract->beginTransaction() #3 D:\svnrepos\WiClub\src\application\controllers\ShopController.php(507): shop->inserttest(Array) #4 E:\php\ZendFramework\library\Zend\Controller\Action.php(513): ShopController->shopaddtestAction() #5 E:\php\ZendFramework\library\Zend\Controller\Dispatcher\Standard.php(289): Zend_Controller_Action->dispatch('shopaddtestActi...') #6 E:\php\ZendFramework\library\Zend\Controller\Front.php(946): Zend_Controller_Dispatcher_Standard->dispatch(Object(Zend_Controller_Request_Http), Object(Zend_Controller_Response_Http)) #7 D:\svnrepos\WiC in E:\php\ZendFramework\library\Zend\Db\Adapter\Pdo\Abstract.php on line 305

似乎是提示已经有一个事务在运行?刚接触ZF不久,不太熟悉,把相关源文件贴上来吧

config.ini

[general]
db.adapter = PDO_MYSQL
db.config.host = localhost
db.config.username = root
db.config.password = 123456
db.config.dbname = testdb 
db.config.charset = utf8
date_default_timezone = "PRC"


Util.php    [所在文件夹 Common,与controllers文件夹,models文件夹同级]

<?php
require_once 'Zend/Config/Exception.php';
require_once 'Zend/Config/Ini.php';
require_once 'Zend/Registry.php';
require_once 'Zend/Db.php';
require_once 'Zend/Db/Table.php';
//require_once 'common/Blowfish.php';
//require_once 'common/Hosts.php';
class Common_Util
{
        public static function getDb($configName,$setcharset=false)
{
if($configName)
{
$config=new Zend_Config_Ini('../config.ini',$configName);
                        $registry= Zend_Registry::getInstance();
                        $registry->set('config',$config);
                        $params=$config->db->config->toArray();
                        $params['options']=array(PDO::ATTR_PERSISTENT => true);
                        $db = Zend_Db::factory($config->db->adapter,$params);


if($setcharset)
{
$charset =($params['charset']);
$db->query("set names $charset;");
}
return $db;
}
else
{
return false;
}
}
}



ShopController.php    [所在文件夹 controllers]

<?php
require_once 'Zend/Session/Namespace.php';
require_once 'Zend/Db.php';
require_once 'Zend/Validate/EmailAddress.php';
require_once 'Zend/Cache.php';
require_once '../application/common/Util.php';
require_once '../application/common/DbBase.php';
require_once '../application/models/jsclass.php';
require_once '../application/models/shop.php';
require_once '../application/models/ajaxpage.php';
require_once '../application/models/shoptest.php';

class ShopController extends Zend_Controller_Action    

protected $_db;
function init() 
        {
           $this->_db=Common_Util::getDb("general",true); //实例化数据库字符串连接
   $this->view->baseUrl = $this->_request->getBaseUrl();
   $this->defaultNs = new Zend_Session_Namespace('Default');
 }
        

         public function shopaddtestAction()
{
$dds=new shop("shop_type",$this->_db);
for($i=2147483645;$i<2147683650;$i++)
{
$data=array("shop_id"=>$i,"type"=>$i);
$dds->inserttest($data);
}

}
}


Shop.php [所在文件夹 models]

<?php
require_once "Zend/Validate/Digits.php";
class Shop 
{
protected $_name = '';
protected $_db;

public function __construct($name=null,$db=null)
{
if($db)
{
$this->_db=$db;
}
if($name)
{
$this->_name=$name;
}
}
        
        public function inserttest($data)
{
if($data)
{
$this->_db->beginTransaction();
try
{
$rs = $this->_db->insert($this->_name,$data);
if($rs)
{
$rs = $this->_db->lastInsertId();
}
return $rs;

$this->_db->commit();
}
catch(Exception $e)
{
$this->_db->rollback();   error_log($e->getMessage());
}
}
return false;
}
}


请各位大牛支招,谢谢!
[解决办法]
执行完query,execute,commit等操作后,要close
[解决办法]

return $rs;
$this->_db->commit();


你这样能commit吗?
[解决办法]
$dds=new shop("shop_type",$this->_db);
        for($i=2147483645;$i<2147683650;$i++)
        {
$this->_db->beginTransaction();
try
            {

            $data=array("shop_id"=>$i,"type"=>$i);           


 $dds->inserttest($data);
$this->_db->commit();
}
            catch(Exception $e)
            {
                $this->_db->rollback();   error_log($e->getMessage());    
            }

        }




   

热点排行