web-dev-qa-db-ja.com

2つのテーブルを結合してYii2グリッドビューで値を取得する方法

Yii2 gridviewウィジェットを使用してデータを表示しています。

messageおよびmessage_triggerという名前の2つのテーブルを使用しています。

messageでは、テーブルの列はobject_modelObject_idです。

message_triggerでは、列はobject_idobject_nameです。

グリッドはテーブルから値を取得しますメッセージ。したがって、グリッドフィールドはObject_modelObject_idです。

今私の問題は、テーブルのObject_nameに基づいてテーブルmessage_triggerobject_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,
    ]);
}
8
JeevaRekha

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

ankitraturi回答 が最良の回答です。モデルから関数を使用して値を取得し、それをグリッドビューで使用したい場合は、以下の手順に従ってください。

  1. モデルに値を返す関数を追加します(ここでは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::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} '],
    ],
]); ?>

これが誰かを助けることを願っています。

3