Laravel: изменить необработанный запрос в построителе запросов или красноречивый

У меня есть этот фрагмент Laravel Query Builder, который работает нормально:

$records = DB::table('users')
    ->select(
        DB::raw('users.*, activations.id AS activation, 
                 (SELECT roles.name FROM roles 
                  INNER JOIN role_users 
                    ON roles.id = role_users.role_id
                  WHERE users.id = role_users.user_id LIMIT 1) 
                  AS role')
    )
    ->leftJoin('activations', 'users.id', '=', 'activations.user_id')
    ->where('users.id', '<>', 1)
    ->orderBy('last_name')
    ->orderBy('first_name')
    ->paginate(10);

Есть ли способ избежать использования сырых запросов и получить тот же результат? Другими словами, как я могу написать это в стиле, более похожем на построитель запросов? Могу я также перевести это в красноречивый запрос?

Спасибо


person Ivan    schedule 05.04.2016    source источник


Ответы (1)


Вы можете использовать selectSub метод для своего запроса.

(1) Сначала создайте ролевой запрос

$role = DB::table('roles')
            ->select('roles.name')
            ->join('roles_users', 'roles.id', '=', 'role_users.role_id')
            ->whereRaw('users.id = role_users.user_id')
            ->take(1);

(2) Второй добавил $role подзапрос как role

DB::table('users')
                ->select('users.*', 'activations.id AS activation')
                ->selectSub($role, 'role') // Role Sub Query As role
                ->leftJoin('activations', 'users.id', '=', 'activations.user_id')
                ->where('users.id', '<>', 1)
                ->orderBy('last_name')
                ->orderBy('first_name')
                ->paginate(10);

Выходной синтаксис SQL

"select `users`.*, `activations`.`id` as `activation`, 
(select `roles`.`name` from `roles` inner join `roles_users` on `roles`.`id` = `role_users`.`role_id` 
where users.id = role_users.user_id limit 1) as `role` 
from `users` 
left join `activations` on `users`.`id` = `activations`.`user_id` 
where `users`.`id` <> ? 
order by `last_name` asc, `first_name` asc 
limit 10 offset 0"
person Nyan Lynn Htut    schedule 08.04.2016
comment
Ой, selectSub () !!! Почему это нигде не упоминается в документации ??? : - / Я также вижу материал whereRaw (): использование этого необработанного запроса - единственный способ добиться результата? Я бы хотел по возможности избегать сырых запросов ... - person Ivan; 08.04.2016
comment
@Ivan Вы можете использовать обычный where метод с использованием Illuminate\Database\Query\Expression. whereRaw('users.id = role_users.user_id') на where('users.id', '=', new Illuminate\Database\Query\Expression('role_users.user_id')) - person Nyan Lynn Htut; 08.04.2016
comment
Большое спасибо! :-) - person Ivan; 08.04.2016