当前位置: 移动技术网 > IT编程>开发语言>PHP > 详解Yii2.0使用AR联表查询实例

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

2017年12月12日  | 移动技术网IT编程  | 我要评论

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'], 
  ], 
]); ?> 

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

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网