1

当我获得一张桌子的数据时,我遇到了一些麻烦。

我正在使用 Doctrine 1 + Codeigniter,问题是数据只获得最后一个注册表。

我没有定义这些表(OpModelos 和 AnSimNavTrans)之间的任何关系,这就是风景:

控制器:

class Modelos extends CI_Controller {

    public function view($idModelo) {
        $aData['site_description'] = 'AutoDato';
        $aData['site_keywords'] = 'keywords';
        $aData['site_robots'] = 'robots';
        $aData['site_author'] = 'author';

        $modelo = Doctrine::getTable('OpModelo')->find($idModelo);
        $modelo_caract = Doctrine::getTable('anCaractUserMo')->getByModeloId($idModelo);
        $modelos_similares_nav = Doctrine::getTable('OpModelo')->getModeloSimNav($idModelo);

        $aData['modelo'] = $modelo;
        $aData['modelo_caract'] = $modelo_caract;
        $aData['modelos_similares_nav'] = $modelos_similares_nav;

        $aData['view'] = 'modelo/view';

        $this->load->view('template', $aData);
    }
}

数据表 AnSimNavTrans

op_modelo_id  cod_mod med_sim
    1           10      0.9
    1           2       0.8
    1           11      0.7
    1           4       0.5
    1           6       0.1

模型

class OpModeloTable extends Doctrine_Table {

    public function getModeloSimNav($idModelo) {
        $query = Doctrine_Query::create();
        $query->from('AnSimNavTrans');
        $query->where('op_modelo_id = ?', $idModelo);
        $query->orderBy('med_sim DESC');
        $query->limit('3');

        $result = $query->execute();

        return $result->toArray();
    }
}

看法:

print_r($modelos_similares_nav);

Array ( [0] => Array ( [op_modelo_id] => 1 [cod_mod] => 11 [med_sim] => 0.7 ) )

正如您在视图中看到的,当我得到查询的数组时,这只显示最后一条记录。

这有什么问题?

4

1 回答 1

1

第一的:

OpModeloTable->getModeloSimNav对 .进行查询对我来说很奇怪AnSimNavTrans。为什么不用AnSimNavTransTable这样做呢?

第二:

如果你想要一个数组,请使用数组而不是使用toArray

$result = $query->execute(array(), Doctrine_Core::HYDRATE_ARRAY);.

用最后一件事进行测试。我不知道为什么当您的解决方案不起作用时这种方式有效。查看代码时,toArray 注释的函数说:

模仿 $query->execute(array(), Doctrine_Core::HYDRATE_ARRAY); 的结果

所以,也许最好不要模仿这个功能,而是实际使用它..

顺便说一句,像我告诉你的那样使用保湿比使用toArray. 使用数组水合背后的想法是,学说不会水合对象(和所有依赖项)。这将在加载页面时为您节省大量时间。

使用时toArray,您将与对象水合,然后将其转换为数组。你浪费了很多时间。

这是修复性能问题的第一步。

于 2013-02-17T09:01:52.753 回答