php - yii 为什么使用 CDbCriteria类,$criteria->join为什么查出来的数据还是一个表里面的?
PHPz
PHPz 2017-04-10 16:11:23
[PHP讨论组]

这个是我在model文件里面写的一个方法。我想将一张表(t) 和 另一张表 c 做外连接(left join)。

    public function pagination($limit, $condition, $order){
        $criteria = new CDbCriteria();
        $criteria->alias = 't';
        $criteria->order = $order;
        $criteria->select = 't.id, c.value';
        $criteria->addCondition($condition);
        $criteria->join = 'left join lp_site_conf as c on t.type=c.id';
        $result['listInfo'] = YiiData($this->findAll($criteria));
        $result['pageCount'] = $pages->getPageCount();
    }

但是 现在查出来的数据是这样的

array(10) {
  [0] => array(9) {
    ["id"] => string(2) "10"
    ["name"] => NULL
    ["type"] => NULL
    ["createuid"] => NULL
    ["createtime"] => NULL
    ["modifytime"] => NULL
    ["description1"] => NULL
    ["description2"] => NULL
    ["status"] => NULL
  }
  [1] => array(9) {
    ["id"] => string(1) "9"
    ["name"] => NULL
    ["type"] => NULL
    ["createuid"] => NULL
    ["createtime"] => NULL
    ["modifytime"] => NULL
    ["description1"] => NULL
    ["description2"] => NULL
    ["status"] => NULL
  }

这些字段都是t表中的,根本没有leftjoin的表的字段,这是什么原因?

PHPz
PHPz

学习是最好的投资!

全部回复(1)
伊谢尔伦

我遇到了和你一样的问题,你是怎么解决的呢?

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号