169 похожих чатов

Ради хохмы перенёс свой запрос в Query Builder. Было: select

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 подсказывать и завершать имена таблиц и столбцов? Иначе совсем тоскливо.

8 ответов

25 просмотров

в 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 использовать нужно. Времени просто сейчас нет растолковать мысль. В доке есть.

Похожие вопросы

Обсуждают сегодня

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта