v.*, c.name as carrier_name,
vt.name as vehicle_type_name,
m.background, m.foreground
from
vehicles v
join
carriers c on c.id = v.carrier_id
join
matches_colors m on m.id = v.matches_color_id
join
vehicle_types vt on vt.id = v.vehicle_type_id
where
c.user_id = :user_id
order by c.name, v.id";
Стало
DB::table('vehicles')
->select('vehicles.*', 'carriers.name as carrier_name', 'vehicle_types.name as vehicle_type_name', 'matches_colors.background', 'matches_colors.foreground')
->join('carriers', 'carriers.id', '=', 'vehicles.carrier_id')
->join('matches_colors', 'matches_colors.id', '=', 'vehicles.matches_color_id')
->join('vehicle_types', 'vehicle_types.id', '=', 'vehicles.vehicle_type_id')
->where('carriers.user_id', $user_id)
->orderBy('carriers.name')
->orderBy('vehicles.id')
->get();
Что ужасно не понравилось, кроме того, что запрос стал нечитаемым и пришлось набирать много лишних букв:
1. Невозможно использовать алиасы в построителе запросов. Приходится постоянно писать полное название таблиц.
2. Функция select в связи с этим превращается в адский ад.
3. Всю структуру таблиц надо держать в голове или лезть сверяться с нею куда-либо
4. Все названия функций и полей вбиваются ручками. Подсказки и автозавершение не работают. А это значит, что возможны опечатки.
Вопрос: есть ли способ заставить IDE подсказывать и завершать имена таблиц и столбцов? Иначе совсем тоскливо.
в DB::table нет
Как нет, если мой запрос работает и возвращает данные?
ты спросилпро подсказки IDE, я на это ответил. Причем тут работоспособность твоего запроса?
Тогда я не понял ответа.
Если делать как это подразумевает Eloquent, то будет что-то вроде $vehicles = Vehicle::query() ->where() ->orderBy(...) ->orderBy(...) ->with(['type', 'carrier', 'color']) ->get(); А потом брать модели и по ним идти и забирать $vehicle->type-> $vehicle->carrier->name $vehicle->color->background
Забирать в представлении? А оно данные уже на клиенте держит, или будет лезть в БД при проходе строк?
Нет, не будет, потому что with().
Я думаю relations использовать нужно. Времени просто сейчас нет растолковать мысль. В доке есть.
Обсуждают сегодня