yii2.0AR两表联查

Posted CFFIRM

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了yii2.0AR两表联查相关的知识,希望对你有一定的参考价值。

首先,建两个关联表。

表一

-- Table structure for article
-- ----------------------------
DROP TABLE IF EXISTS `article`;
CREATE TABLE `article` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT ‘自增id‘,
`new` text,
`t_id` int(11) DEFAULT NULL COMMENT ‘关联id‘,
PRIMARY KEY (`id`)
) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;

表二

-- ----------------------------
-- Table structure for type
-- ----------------------------
DROP TABLE IF EXISTS `type`;
CREATE TABLE `type` (
`t_id` int(11) NOT NULL AUTO_INCREMENT,
`t_name` varchar(255) DEFAULT NULL COMMENT ‘分类名‘,
PRIMARY KEY (`t_id`)
) ENGINE=MyISAM AUTO_INCREMENT=5 DEFAULT CHARSET=utf8;

两表关联字段是 article.t_id = type.t_id

表建好之后,前戏就完成了,下边开始干活。

 

<?php

namespace appmodels;

use yiidbActiveRecord;
class Type extends ActiveRecord{
    public static function tableName(){
        return ‘type‘;
    }

}

第二个 AR Model 就稍微多了一丢丢了  请看

<?php

namespace appmodels;

use yiidbActiveRecord;
class Article extends ActiveRecord{

    public static function tableName(){
        return‘article‘;
    }
    //关联表      get(关联表Model名)
    public function getType(){
                           参数一 关联Model名   参数二 关联字段 不能写表.t_id 自己默认后边是本Model的表id  前边是关联表的id
        return $this->hasOne(Type::className(),[‘t_id‘=>‘t_id‘]);
    }

}

这就关联上了。

下面就是,查询了:

<?php


namespace appcontrollers;

use yiiwebController;
use appmodelsArticle;
class TestController extends Controller{

    //两表联查 数据
    public function actionIndex(){
                                     //关联表名 注意大小写    查询字段                       asArray()转为数组 否则是对象               
        $model = Article::find()->joinWith([‘type‘])->select(‘new,t_name,article.t_id‘)->asArray()->all();
        print_r($model);
    }

}

好了,完成了,就是这么简单。

以上是关于yii2.0AR两表联查的主要内容,如果未能解决你的问题,请参考以下文章

单的两表联查电影管理系统,下拉框回显

两表联查 条件的问题

iwebshop两表联查

thinkjs——两表联查

mybatis-plus两表联查带分页带模糊查询所有订单信息

sql两表联查只要左表一条数据但是查完都多一条