Я вывожу таблицу, и вывожу в ней также роль пользователя
мой grid widget
<?= GridView::widget([
'dataProvider' => $dataProvider,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
'id',
'username',
'email:email',
'status',
'created_at',
[
'attribute' => 'roles',
'value' => function ($user){
if(!empty($userRole = $user->getRoles()[0])){
return $userRole;
}
}
],
['class' => 'yii\grid\ActionColumn'],
],
]); ?>
функция getRoles
public function getRoles(){
$roles = Yii::$app->authManager->getRolesByUser($this->getId());
return ArrayHelper::getColumn($roles, 'name', false);
}
Роль выводиться, но есть проблема. количество запросов в базу данных, зависит от количества пользователей выведенных в таблицу на странице пагинации(к примеру если в таблице выводиться 30 пользователей то соотвецтвенно будет 30 запросов в БД, чтобы получить имя роли). Как можно улучшить это и сократить количество запросов в базу данных?
Сборка персонального компьютера от Artline: умный выбор для современных пользователей