如何在Yii2 gridview中连接两个表并获取值 [英] How to join two tables and get values in Yii2 gridview

查看:110
本文介绍了如何在Yii2 gridview中连接两个表并获取值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我使用Yii2 gridview小部件来显示数据。



我使用两个名为 message message_trigger



消息表列中, object_model Object_id
$ b message_trigger 中,列是 object_id object_name



网格从表格消息中获取值。因此,网格字段是 Object_model Object_id

现在我的问题是我需要从表 message_trigger 中显示 Object_name c $ c>基于表消息中的 object_id

在我的窗体我已经使用过这样的网格

 <?= GridView :: widget([
'dataProvider'=> ; $ dataProvider,
'filterModel'=> $ searchModel,
'columns'=> [
['class'=>'yii\grid\SerialColumn'],
'object_model',
'object_id',
['class'=>'yii\grid\ActionColumn','template'=>'{view} {update} {delete}'],
],
]); ?>

在模型中,我使用了

  public function search($ params){
$ query = AlertTrigger :: find() - >其中(['alert_id'=> $ params ['id']]) - > andWhere([ '!=', '状态',2]);
$ dataProvider = new ActiveDataProvider([
'query'=> $ query,
]);


解决方案

> Message Model

  public function getMessageTrigger()
{
return $ this-> hasOne(MessageTrigger :: className(),['object_id'=>'object_id']);
}

视图

 <?= GridView :: widget([
'dataProvider'=> $ dataProvider,
'filterModel'=> $ searchModel,
'columns'=> [
['class'=>'yii\grid\SerialColumn'],
'object_model',
'object_id',
[
'label'=>'Name',
'value'=>'messageTrigger.object_name',
],
['class'=>'yii\\ \\ grid \ActionColumn','template'=>'{view} {update} {delete}'],
],
]); ?>


I'm using Yii2 gridview widget to display the data.

I'm using two tables named as message and message_trigger.

In message table columns are object_model, Object_id.

In message_trigger the column are object_id, object_name.

The grid get the values from the table message. So grid fields are Object_model, Object_id.

Now my problem is I need to show Object_name from the table message_trigger based on the object_id from the table message.

In my form I have used grid like this

<?= GridView::widget([
    'dataProvider' => $dataProvider,
    'filterModel' => $searchModel,
    'columns' => [
        ['class' => 'yii\grid\SerialColumn'],
        'object_model',
        'object_id',
        ['class' => 'yii\grid\ActionColumn', 'template' => '{view} {update} {delete} '],
    ],
]); ?>

In model I have used

public function search($params){
    $query = AlertTrigger::find()->where(['alert_id'=>$params['id']])->andWhere(['!=','status',2]);
    $dataProvider = new ActiveDataProvider([
        'query' => $query,
    ]);
}

解决方案

In Message Model

public function getMessageTrigger()
{
    return $this->hasOne(MessageTrigger::className(), ['object_id' => 'object_id']);
}

in view

<?= GridView::widget([
    'dataProvider' => $dataProvider,
    'filterModel' => $searchModel,
    'columns' => [
        ['class' => 'yii\grid\SerialColumn'],
        'object_model',
        'object_id',
        [
            'label' => 'Name',
            'value' => 'messageTrigger.object_name',
        ],
        ['class' => 'yii\grid\ActionColumn', 'template' => '{view} {update} {delete} '],
    ],
]); ?>

这篇关于如何在Yii2 gridview中连接两个表并获取值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆