欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

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

程序员文章站 2024-03-12 12:00:50
yii2.0中使用联表查询有两种办法,第一种是查询构建器(query builder),第二种使用活动记录(active record),中文网对查询构建器讲的很详细,ar...

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

两个表

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

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

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

class article extends \yii\db\activerecord 
{ 
  //这里声明被关联字段 
  public $class_name; 
   
  /** 
   * @inheritdoc 
   */ 
  public static function tablename() 
  { 
    return '{{%article}}'; 
  } 
  ... 
 //关联 mysite_article_class 表 
  public function getarticleclass(){ 
    /** 
    * 第一个参数为要关联的子表模型类名称, 
    * 第二个参数指定通过子表的 id 去关联主表的 article_class 字段 
    */ 
    return $this->hasmany(articleclass::classname(), ['id' => 'article_class']); 
  }  
   
} 

2、在controllers {articlecontroller}中使用,

public function actionindex() 
  {   
    $article = new article(); 
    if(yii::$app->request->get('class')){ 
      $query = article::find() 
          ->joinwith('articleclass') 
          ->select(['{{%article}}.*,{{%article_class}}.class_name']) 
          ->where(['article_class' => yii::$app->request->get('class')]); 
      $dataprovider = new activedataprovider([ 
        'query' => $query, 
      ]); 
       
    }else{ 
      $query = article::find() 
          ->joinwith('articleclass') 
          ->select(['{{%article}}.*,{{%article_class}}.class_name']); 
      $dataprovider = new activedataprovider([ 
        'query' => $query, 
      ]); 
       
    } 
    return $this->render('index', [ 
      'dataprovider' => $dataprovider, 
      'model' => $article, 
    ]); 
  } 

3、在view {gridview}中使用

<?= gridview::widget([ 
  'dataprovider' => $dataprovider, 
  'columns' => [ 
    ['class' => 'yii\grid\serialcolumn'], 
    'id', 
    //'article_content:ntext', 
    [ 
      'value'=>'class_name', 
      'label'=>'文章分类', 
    ], 
    'article_title', 
    'article_addtime:datetime', 
    // 'article_updatetime:datetime', 
    // 'article_author', 
    ['class' => 'yii\grid\actioncolumn'], 
  ], 
]); ?> 

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