如何在Yii2 gridview中连接两个表并获取值

时间:2015-08-23 11:32:24

标签: gridview yii2 yii2-model

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

我使用两个名为消息 message_trigger 的表。

消息表中,列为object_modelObject_id

message_trigger 中,该列为object_idobject_name

网格获取表消息中的值。因此,网格字段为Object_modelObject_id

现在我的问题是,我需要根据表格消息中的Object_name来显示表格message_trigger中的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()->where(['alert_id'=>$params['id']])->andWhere(['!=','status',2]);
    $dataProvider = new ActiveDataProvider([
        'query' => $query,
    ]);
}

2 个答案:

答案 0 :(得分:9)

Message模型中

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

答案 1 :(得分:3)

ankitraturi answer是最好的答案。如果有人想使用模型中的函数获取值并在gridview中使用它,请按照以下步骤操作。

  1. 添加在模型中返回值的函数(这里我使用Message模型)。
  2. public static function get_message_trigger($id){
        $model = MessageTrigger::find()->where(["object_id" => $id])->one();
        if(!empty($model)){
            return $model->object_name;
        }
    
        return null;
    }
    
    1. 在Gridview中使用如下所示。
    2. <?= GridView::widget([
          'dataProvider' => $dataProvider,
          'filterModel' => $searchModel,
          'columns' => [
              ['class' => 'yii\grid\SerialColumn'],
              'object_model',
              'object_id',
              [
                  'label' => 'Name',
                  'value' => function($data){
                      return Message::get_message_trigger($data->object_id)
                  },
              ],
              ['class' => 'yii\grid\ActionColumn', 'template' => '{view} {update} {delete} '],
          ],
      ]); ?>
      

      希望这会对某人有所帮助。