来自Zend的DB Adapter的SetIntegrityCheck

时间:2013-03-04 10:56:12

标签: zend-framework zend-db zend-db-select

您好我想在zend db select中使用join。我知道setintegritycheck()在连接中很重要。当我有一个像

这样的模型对象时,我知道如何实现它
$select = $this->select();
$select->setintegritycheck(false);
$select->from(array('info'),array())
            ->join(array('cfields'),'info.class=cfields.class_id',array('field_id','type_id'))
            ->where('info.id=2');

但在我的情况下,我不是模特儿。我有dbadapter。现在我正在写这样的查询

    $dbAdapter = MyManager::getDbAdapator('project');
    $select = $dbAdapter->select('info');

    $select->setIntegrityCheck(false);
    $select->from(array('info'),array())
            ->join(array('cfields'),'info.class=cfields.class_id',array('field_id','type_id'))
            ->where('info.id=2');

该行

$dbAdapter = MyManager::getDbAdapator('project');

返回项目数据库的适配器,我已经搞砸了。现在在这种情况下,我的select对象来自db adapter,所以当我尝试获取setintegritycheck时,它会生成错误

Unrecognized method 'setIntegrityCheck()' 

我可以告诉我在这种情况下如何进行完整性检查。

1 个答案:

答案 0 :(得分:1)

setIntegrityCheck()Zend_Db_Table_Select上的一种方法。如果要从数据库适配器构建选择,则使用Zend_Db_Select代替,并且没有完整性检查,因此您无需担心禁用它。

完整性检查检查查询返回的列是否与表上的列匹配,因此仅在Zend_Db_Table的上下文中有意义。