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 ответов

21 просмотр

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

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
5
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта