Как объединить две таблицы и получить значения в Yii2 gridview

Я использую коде с Yii2 виджет gridview для отображения данных.

Я использую две таблицы с именем и message_trigger.

на столбцы таблицы object_model, Object_id.

на message_trigger колонки object_id, object_name.

сетка получает значения из таблицы . Поэтому сетка полей Object_model, Object_id.

теперь моя проблема в том, что мне нужно показать Object_name из таблицы message_trigger на основе object_id из таблицы .

в моей форме я использовал сетку, как это

<?= GridView::widget([
    'dataProvider' => $dataProvider,
    'filterModel' => $searchModel,
    'columns' => [
        ['class' => 'yiigridSerialColumn'],
        'object_model',
        'object_id',
        ['class' => 'yiigridActionColumn', '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 ответов


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

ankitraturi ответ это лучший ответ. Если кто-то хочет получить значение с помощью функции из модели и использовать его в gridview, выполните следующие действия.

  1. добавьте функцию, возвращающую значение в модели a(здесь я использую Message модель).
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 Используйте, как показано ниже.
<?= 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} '],
    ],
]); ?>

надеюсь, это поможет кому-то.