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

如何在yii2gridview中连接两个表并获取值,gridview,yii2,yii2-model,Gridview,Yii2,Yii2 Model,我正在使用Yii2gridview小部件来显示数据 我使用了两个名为message和message\u trigger的表 在消息中表列为对象\模型,对象\ id 在消息\u触发器中列为对象\u id,对象\u名称 网格从表消息中获取值。所以网格字段是Object\u model,Object\u id 现在我的问题是,我需要根据表消息中的对象id从表消息触发器中显示对象名称 在我的表格中,我使用了这样的网格 <?= GridView::widget([ 'dataProvider

我正在使用Yii2gridview小部件来显示数据

我使用了两个名为messagemessage\u trigger的表

消息中表列为
对象\模型
对象\ id

消息\u触发器中列为
对象\u id
对象\u名称

网格从表消息中获取值。所以网格字段是
Object\u model
Object\u id

现在我的问题是,我需要根据表消息中的
对象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 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} '],
    ],
]); ?>

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

  • 添加在a模型中返回值的函数(这里我使用
    Message
    model)
  • 在Gridview中,使用如下所示
  • 
    
    希望这能对其他人有所帮助。

    如果我需要使对象名称也可排序怎么办??
    <?= 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} '],
        ],
    ]); ?>
    
    public static function get_message_trigger($id){
        $model = MessageTrigger::find()->where(["object_id" => $id])->one();
        if(!empty($model)){
            return $model->object_name;
        }
    
        return null;
    }
    
    <?= 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} '],
        ],
    ]); ?>