当前位置:Gxlcms > php框架 > 详解Yii2.0使用AR联表查询实例

详解Yii2.0使用AR联表查询实例

时间:2021-07-01 10:21:17 帮助过:16人阅读

Yii2.0中使用联表查询有两种办法,第一种是查询构建器(Query Builder),第二种使用活动记录(Active Record),中文网对查询构建器讲的很详细,AR则说的很坑爹,下面贴出自己实践的方法,以供参考。

两个表

{{%article}} 和 {{%article_class}}

{{%article}} .article_class关联{{%article_class}}.id

1、要使用AR做关联查询,首先在models {Article} 中创建关联:

  1. class Article extends \yii\db\ActiveRecord
  2. {
  3. //这里声明被关联字段
  4. public $class_name;
  5. /**
  6. * @inheritdoc
  7. */
  8. public static function tableName()
  9. {
  10. return '{{%article}}';
  11. }
  12. ...
  13. //关联 mysite_article_class 表
  14. public function getArticleClass(){
  15. /**
  16. * 第一个参数为要关联的子表模型类名称,
  17. * 第二个参数指定通过子表的 id 去关联主表的 article_class 字段
  18. */
  19. return $this->hasMany(ArticleClass::className(), ['id' => 'article_class']);
  20. }
  21. }

2、在controllers {ArticleController}中使用,

  1. public function actionIndex()
  2. {
  3. $article = new Article();
  4. if(Yii::$app->request->get('class')){
  5. $query = Article::find()
  6. ->joinWith('articleClass')
  7. ->select(['{{%article}}.*,{{%article_class}}.class_name'])
  8. ->where(['article_class' => Yii::$app->request->get('class')]);
  9. $dataProvider = new ActiveDataProvider([
  10. 'query' => $query,
  11. ]);
  12. }else{
  13. $query = Article::find()
  14. ->joinWith('articleClass')
  15. ->select(['{{%article}}.*,{{%article_class}}.class_name']);
  16. $dataProvider = new ActiveDataProvider([
  17. 'query' => $query,
  18. ]);
  19. }
  20. return $this->render('index', [
  21. 'dataProvider' => $dataProvider,
  22. 'model' => $article,
  23. ]);
  24. }

3、在view {GridView}中使用

  1. <?= GridView::widget([
  2. 'dataProvider' => $dataProvider,
  3. 'columns' => [
  4. ['class' => 'yii\grid\SerialColumn'],
  5. 'id',
  6. //'article_content:ntext',
  7. [
  8. 'value'=>'class_name',
  9. 'label'=>'文章分类',
  10. ],
  11. 'article_title',
  12. 'article_addtime:datetime',
  13. // 'article_updatetime:datetime',
  14. // 'article_author',
  15. ['class' => 'yii\grid\ActionColumn'],
  16. ],
  17. ]); ?>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

人气教程排行