gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 21:40:01 25 4
gpt4 key购买 nike

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

我使用两个名为 messagemessage_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' => '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,
]);
}

最佳答案

消息模型中

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

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

关于gridview - 如何在 Yii2 gridview 中连接两个表并获取值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32166185/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com