От автора: приветствую вас, друзья. Мы продолжаем цикл статей, посвященных знакомству с фреймворком Yii2. В этой и следующих статьях мы немного больше внимания уделим классу Yii2 Active Record, который предлагает объектный интерфейс для данных БД. Мы познакомимся с наиболее популярным набором методов класса, как то: where, update, save, count, delete и т.п.
Напомню, в одной из предыдущих статей мы вскользь коснулись класса Active Record. Для беглого знакомства мы создали контроллер PostController и модель Category. Также у нас имеется таблица category в БД. По умолчанию модель работает, как вы помните, с одноименной таблицей. Выглядит наша модель очень просто:
1 2 3 4 5 6 7 8 9 10 | <?php namespace app\models; use yii\db\ActiveRecord; class Category extends ActiveRecord { } |
Для того, чтобы достать коллекцию записей из таблицы category, мы использовали всего пару строк кода:

Фреймворк Yii2. Быстрый старт
Получите курс и узнайте, как с помощью фреймворка Yii2 разрабатывать веб-приложения на примере блога
Смотреть курс 1 2 | $modelCategory = new Category(); $cats = $modelCategory::find()->all(); |
В этих строках мы как раз и используем возможности класса Active Record. В общем случае для работы с указанным классом необходимо:
получить объект модели и создать объект запроса, вызвав метод find;
при необходимости настроить объект запроса, обращаясь к методам построения запроса (where, limit, orderBy и т.д.);
вызвать необходимый метод получения данных, чаще всего это будут all, one или count.
В коде выше мы фактически пропустили этап настройки запроса и в результате запрос получился примитивным, вида SELECT * FROM category. Давайте теперь попробуем совсем немного усложнить его, обратившись к нескольким методам настройки запросов.
Самый простой вариант — метод where. Как вы уже догадались, это аналог одноименного оператора в языке запросов SQL. Попробуем вытащить категорию с id = 3:

Фреймворк Yii2. Быстрый старт
Получите курс и узнайте, как с помощью фреймворка Yii2 разрабатывать веб-приложения на примере блога
Смотреть курс 1 2 3 4 5 | $modelCategory = new Category(); $cats = $modelCategory::find()->where('id=3')->all(); echo '<pre>'; print_r($cats); die; |
В итоге мы получим один объект в массиве с категорией, id которой равняется запрошенному.
В качестве параметра методу when мы передали строковое выражение. Однако, данный метод понимает также и формат массива. Например, тот же результат мы получим и с такой записью:
1 | $cats = $modelCategory::find()->where(['id' => 3])->all(); |
Также мы можем передать массив операторов. Давайте для примера выполним поиск, используя оператор LIKE в запросе.
1 | $cats = $modelCategory::find()->where(['like', 'name', 's'])->all(); |
Данный вариант записи сформирует запрос вида SELECT * FROM category WHERE name LIKE ‘%s%’. В результате мы получим что-то подобное:
Как видим, ничего сложного. В следующих статьях мы продолжим знакомство с классом Active Record и получением различных вариантов данных. Больше о фреймворке вы можете узнать из наших бесплатных или платных уроков. Также создание простейшего блога на Yii2 можно посмотреть в этом цикле уроков.

Фреймворк Yii2. Быстрый старт
Получите курс и узнайте, как с помощью фреймворка Yii2 разрабатывать веб-приложения на примере блога
Смотреть курс