首页 文章

Yii2在gridview中获取多对多关系的数据并应用过滤器

提问于
浏览
0

我正在使用Yii2框架开发一个Web应用程序,我现在面临一个问题 . 我想在gridview中显示多对多关系中的数据,并且稍后可以从这些字段中进行过滤 .

我已经阅读了官方文档 here ,一些stackoverflow发布 like this 和其他资源但似乎无法让它工作 . 我有3个表: actividadplan_actividadcirculo_icareactividadplan_actividad 有关, circulo_icare 也与它有关( plan_actividad 是联结表) . 所以我在 Actividad 模型中定义了以下关系:

class Actividad extends \yii\db\ActiveRecord 
{
   .... 

public function getPlanActividad()
{
    return $this->hasMany(PlanActividad::classname(), ['act_id' => 'act_id']);
}

public function getCirculo()
{
    return $this->hasMany(CirculoIcare::classname(), ['cirica_id' => 'act_id'])->via('planActividad');
}

...
}

在我看来 index.php 我试图在gridview中显示这样的值:

<?= GridView::widget([
    'dataProvider' => $dataProvider,
    // 'filterModel' => $searchModel,
    'columns' => [
        ['class' => 'yii\grid\SerialColumn'],

        // 'act_id',
        ['attribute' => 'Codigo Evento', 'value' => 'act_numorden'],
        ['attribute' => 'Nombre Evento', 'value' => 'act_nombre'],
        ['attribute' => 'Fecha Evento', 'value' => 'act_fecha'],
        ['attribute' => 'Locacion', 'value' => 'locacion.loc_nombre'],
        [
        'attribute' => 'Circulo',
        'value' => 'circulo.cirica_nombre',

        ],
        ['attribute' => 'Circulo id',
         'value' => 'planActividad.cirica_id',
        ],
        // 'act_horaini',
        // 'act_horafin',
        // 'act_idencuesta',
        // 'act_vigencia:boolean',
        // 'loc_id',

        ['class' => 'yii\grid\ActionColumn'],
    ],
]); ?>

问题是,我无法使用 circulo 关系显示任何值,它始终显示 (not set) . 如果我在 getPlanActividad() 中使用 hasOne() 更改了 hasMany ,那么它会显示一些值(根据plan_actividad表中存在的cirica_id,它应该只有11个中的2个),但这些都不正确 . 我知道我可以稍后在搜索视图中过滤这些字段但是我没有像我预期的那样工作 .

任何帮助将不胜感激,如果需要更多信息,请告诉我,并提前感谢您 .

1 回答

  • 0

    回答我自己的问题(来自yii官方论坛的 softark ) .

    为了使关系按预期工作,我不得不改变:

    public function getCirculos()
    {
         return $this->hasMany(CirculoIcare::classname(), ['cirica_id' => 'act_id'])->via('planActividad');
    }
    

    public function getCirculos()
    {
         return $this->hasMany(CirculoIcare::classname(), ['cirica_id' => 'cirica_id'])->via('planActividad');
    }
    

    并在gridview中使用 callback 函数来显示正确的值,因为 hasMany 关系给出了一个模型数组和 not 单个模型 . 所以我将gridview代码修改为:

    <?= GridView::widget([
        'dataProvider' => $dataProvider,
        // 'filterModel' => $searchModel,
        'columns' => [
            ['class' => 'yii\grid\SerialColumn'],
    
            ...
    
            ['attribute' => 'circulo',
             'value' => function($model){
                $items = [];
                foreach($model->circulos as $circulo){
                    $items[] = $circulo->cirica_nombre;
                }
                return implode(', ', $items);
             }],
    
            ...
    
            ['class' => 'yii\grid\ActionColumn'],
        ],
    ]); ?>
    

    这给出了预期的结果 . 然后,您可以通过调整搜索模型轻松地通过关系字段应用过滤器 .

相关问题