Laravel QueryBuilder. Базовый (пустой) запрос

При динамическом создании запроса есть необходимость сначала создать базовый запрос, что-то эквивалентное:

SELECT * FROM some_table

к которому в дальнешем добавятся условия и/или агрегации на основе параметров.

$query = $query->orderBy('name', 'desc')->take(10);

Нужен Model::all() без его выполнения и это метод newQuery().

2 метода создания базового построителя

Cтатический вызов. Создает новый экземпляр модели и возвращает вызов newQuery().

$builder = Model::query();

Если есть экземпляр модели:

$builder = $model->newQuery();

Похожие записи

Laravel migration: Specified key was too long

В Laravel 5.4 кодировкой базы данных по умолчанию стала utf8mb4. Это повлияло на приложения, использующие MySQL v5.7.7 и меньше. Во время выполненния миграций, может вывалитсья ошибка Specified key was too long.

27 августа 2017 г. в Laravel

Про сохранение полей даты в Eloquent

Если в моделе не указать

protected $dates = ['something_at'];

То надо делать формат

// Поле типа date 
'something_at' => Carbon::now()->addDays(7)->format('Y-m-d'),

// Поле типа date 
'something_at' => Carbon::now()->addDays(7)->format('Y-m-d H:i:s'),

Laravel Where Exists Clauses

Метод whereExists позволяет написать SQL-условия where exists. Метод whereExists принимает в качестве аргумента замыкание, которое получит экземпляр конструктора запросов, позволяя вам определить запрос для помещения в условие "exists":

09 октября 2018 г. в Laravel