Commit a6813325 by Alexander Makarov

Edited Russian translation of Upgrading from Version 1.1 guide

parent 063a4ebf
Обновление с версии 1.1 Обновление с версии 1.1
======================= ====================
Между версиями 1.1 и 2.0 существует много различий, так как Yii был полностью переписан для версии 2.0. Между версиями 1.1 и 2.0 существует много различий, так как Yii был полностью переписан для версии 2.0.
Таким образом, обновление с версии 1.1 не является таким же тривиальным как обновление между минорными версиями. Таким образом, обновление с версии 1.1 не является таким же тривиальным как обновление между минорными версиями.
В данном руководстве по обновлению приведены основные различия между двумя версиями. В данном руководстве приведены основные различия между двумя версиями.
Если прежде вы не использовали Yii 1.1, вы можете пропустить данный раздел и перейти к разделу [Начало работы][start-installation.md]. Если прежде вы не использовали Yii 1.1, вы можете сразу перейти к разделу «[Начало работы][start-installation.md]».
Также учтите, что Yii 2.0 включает больше нового функционала, чем тот, который будет описан здесь. Настоятельно рекомендуется, Также учтите, что в Yii 2.0 гораздо больше новых возможностей, чем описано далее. Настоятельно рекомендуется, изучить
что вы прочтете все руководство, чтобы узнать какой функционал был добавлен. Возможно, что необходимый функционал, который всё руководство. Вполне возможно, что то, что раньше приходилось разрабатывать самостоятельно теперь является частью
вы до этого разрабатывали сами, теперь является частью фреймворка. фреймворка.
Установка Установка
--------- --------
Yii 2.0 полностью основан на [Composer](https://getcomposer.org/), который де факто является менеджером зависимостей для PHP. Yii 2.0 широко использует [Composer](https://getcomposer.org/), который является основным менеджером зависимостей для PHP.
Установка фреймворка, также как и расширений, осуществляется через Composer. Более детальные сведения по установке Yii 2.0 Установка как фреймворка, так и расширений, осуществляется через Composer. Подробно о установке Yii 2.0 вы можете узнать
приведены в разделе [Установка Yii](start-installation.md). Сведения о том, как создавать расширения для Yii 2.0 или адаптировать из раздела «[Установка Yii](start-installation.md)». О том, как создавать расширения для Yii 2.0 или адаптировать
уже имеющиеся расширения для версии 1.1 под версию 2.0, приведены в разделе [Создание Расширений](extend-creating-extensions.md). уже имеющиеся расширения от версии 1.1, вы можете узнать из раздела «[Создание расширений](extend-creating-extensions.md)».
Требования PHP Требования PHP
-------------- -------------
Yii 2.0 использует PHP 5.4 или выше, который включает большое количество улучшений по сравнению с версией 5.2, которая использовалась Для работы Yii 2.0 необходим PHP 5.4 или выше. Данная версия включает большое количество улучшений по сравнению с
Yii 1.1. Таким образом, существует много различий в языке, которые вы должны принимать во внимание. версией 5.2, которая использовалась Yii 1.1. Таким образом, существует много различий в языке, которые вы должны принимать
Ниже приведены основные изменения в PHP: во внимание:
- [Пространства имен](http://php.net/manual/ru/language.namespaces.php); - [Пространства имён](http://php.net/manual/ru/language.namespaces.php);
- [Анонимные функции](http://php.net/manual/ru/functions.anonymous.php); - [Анонимные функции](http://php.net/manual/ru/functions.anonymous.php);
- Использование короткого синтаксис для массивов: `[...элементы...]` вместо `array(...элементы...)`; - Использование короткого синтаксиса для массивов: `[...элементы...]` вместо `array(...элементы...)`;
- Использование сокращенных тегов `<?=` для вывода в файлах представлений. - Использование короткого echo `<?=` для вывода в файлах представлений. С версии PHP 5.4 данную возможность можно
С версии PHP 5.4 данную возможность можно использовать не опасаясь; использовать не опасаясь;
- [классы и интерфейсы SPL](http://php.net/manual/ru/book.spl.php); - [Классы и интерфейсы SPL](http://php.net/manual/ru/book.spl.php);
- [Позднее статическое связывание (LSB)](http://php.net/manual/ru/language.oop5.late-static-bindings.php); - [Позднее статическое связывание (LSB)](http://php.net/manual/ru/language.oop5.late-static-bindings.php);
- [Классы для дат и времени](http://php.net/manual/ru/book.datetime.php); - [Классы для дат и времени](http://php.net/manual/ru/book.datetime.php);
- [Трейты](http://php.net/manual/ru/language.oop5.traits.php); - [Трейты](http://php.net/manual/ru/language.oop5.traits.php);
- [Интернационализация (Intl)](http://php.net/manual/ru/book.intl.php); Yii 2.0 использует расширение PHP `intl` - [Интернационализация (intl)](http://php.net/manual/ru/book.intl.php); Yii 2.0 использует расширение PHP `intl`
для различного функционала интернационализации. для различного функционала интернационализации.
Пространства имен Пространства имён
----------------- ---------------
Одним из основных изменений в Yii 2.0 является использование пространств имён. Почти каждый класс фреймворка
находится в пространстве имён, например, `yii\web\Request`. Префикс "С" в именах классов больше не используется.
Имена классов соответствуют структуре директорий. Например, `yii\web\Request` указывает, что соответсвующий класс
находится в файле `web/Request.php` в директории фреймворка.
Одним из основных изменений в Yii 2.0 является использование пространств имен. Почти каждый класс фреймворка Благодаря загрузчику классов Yii, вы можете использовать любой класс фреймворка без необходимости непосредственно
находится в пространстве имен, например, `yii\web\Request`. Префикс "С" больше не используется в именах классов. подключать его.
Соглашение именования классов следует структуре папки, в которой располагается класс. Например, `yii\web\Request`
означает, что соответсвующий класс находится в файле `web/Request.php` в папке Yii фреймворка.
(Благодаря загрузчику классов Yii, вы можете использовать любой класс фреймворка без необходимости непосредственно
подключать его).
Компонент и Объект Компонент и объект
------------------ ----------------
В Yii 2.0 класс `CComponent` из версии 1.1 был разделен на два класса: [[yii\base\Object]] и [[yii\base\Component]]. В Yii 2.0 класс `CComponent` из версии 1.1 был разделён на два класса: [[yii\base\Object]] и [[yii\base\Component]].
Класс [[yii\base\Object|Object]] является простым базовым классом, который позволяет использовать [геттеры и сеттеры](concept-properties.md) для свойств. Класс [[yii\base\Object|Object]] является простым базовым классом, который позволяет использовать
Класс [[yii\base\Component|Component]] наследуется от класса [[yii\base\Object|Object]] и поддерживает [события](concept-events.md) и [геттеры и сеттеры](concept-properties.md) для свойств. Класс [[yii\base\Component|Component]] наследуется от
[поведения](concept-behaviors.md). класса [[yii\base\Object|Object]] и поддерживает [события](concept-events.md) и [поведения](concept-behaviors.md).
Если вашему классу не нужно использовать функционал событий или поведений, вы можете использовать [[yii\base\Object|Object]] в качестве Если вашему классу не нужны события или поведения, вы можете использовать [[yii\base\Object|Object]] в качестве
базового класса. В основном это случаи, когда классы представляют собой базовые структуры. базового класса. В основном это относится к классам, представляющим собой базовые структуры данных.
Конфигурация объекта Конфигурация объекта
-------------------- ------------------
Класс [[yii\base\Object|Object]] предоставляет единый способ конфигурирования объектов. Любой дочерний класс
[[yii\base\Object|Object]] может определить конструктор (если нужно) как показано ниже. Это позволит конфигурировать
его универсально:
Класс [[yii\base\Object|Object]] предоставляет единый способ конфигурирования объектов. Любой дочерний класс [[yii\base\Object|Object]]
может определить конструктор (если нужно) для своей конфигурации следующим образом:
```php ```php
class MyClass extends \yii\base\Object class MyClass extends \yii\base\Object
...@@ -103,14 +106,14 @@ $object = Yii::createObject([ ...@@ -103,14 +106,14 @@ $object = Yii::createObject([
], [$param1, $param2]); ], [$param1, $param2]);
``` ```
Более детальная информация о конфигурации представлена в разделе [Конфигурации объектов](concept-configurations.md). Более подробная информация о конфигурации представлена в разделе «[Настройки](concept-configurations.md)».
События События
------- -------
В Yii1, события создавались с помощью объявления метода `on` (например, `onBeforeSave`). В Yii2 вы можете теперь В Yii 1, события создавались с помощью объявления метода `on` (например, `onBeforeSave`). В Yii2 вы можете использовать
использовать любое имя события. Вы возбуждаете ивенты с помощью вызова метода [[yii\base\Component::trigger()|trigger()]]. любое имя события. Вызывать события можно при помощи метода [[yii\base\Component::trigger()|trigger()]].
```php ```php
$event = new \yii\base\Event; $event = new \yii\base\Event;
...@@ -121,64 +124,61 @@ $component->trigger($eventName, $event); ...@@ -121,64 +124,61 @@ $component->trigger($eventName, $event);
```php ```php
$component->on($eventName, $handler); $component->on($eventName, $handler);
// To detach the handler, use: // убираем обработчик
// $component->off($eventName, $handler); // $component->off($eventName, $handler);
``` ```
Есть также и другие улучшения в функционале событий. Более детальная информация о конфигурация представлена в разделе [События](concept-events.md). Есть и другие улучшения по части событий, подробно описанные в в разделе «[События](concept-events.md)».
Псевдонимы пути Псевдонимы пути
--------------- -------------
Yii 2.0 расширяет способ использования псевдонимов пути как для файлов и папок, так и для URL. В Yii 2.0 также В Yii 2.0 псевдонимы используются более широко и применяются как к путям в файловой системе, так и к URL. Теперь, для
теперь требуется, чтобы имя псевдонима начиналось с символа `@`, для разграничения псевдонимов от обычных того, чтобы отличать псевдонимы от обычных путей и URL, требуется, чтобы имя псевдонима начиналось с символа `@`.
путей файлов/папок и URL. Например, псевдоним `@yii` соответствует установочной папке Yii. Псевдонимы пути используются Например, псевдоним `@yii` соответствует директории, в которую установлен Yii. Псевдонимы пути используются во многих
во многих местах кода Yii. Например, [[yii\caching\FileCache::cachePath]] может использовать как псевдоним пути так и местах. Например, значение свойства [[yii\caching\FileCache::cachePath]] может быть как псевдонимом пути так и
обычный путь к папке. обычным путём к папке.
Псевдонимы пути тесно связаны с пространством имен классов. Рекомендуется, что вы определите псевдоним пути для Псевдонимы пути тесно связаны с пространством имён классов. Рекомендуется определять псевдоним пути для каждого корневого
каждого базового пространства имен, таким образом загрузчик классов Yii может использоваться без какой-либо дополнительной пространства имён, что позволяет использовать загрузчик классов Yii без какой-либо дополнительной настройки. Например,
конфигурации. Например, потому, что `@yii` соответствует установочной папке Yii, класс `yii\webRequest` может быть загружен. так как `@yii` соответствует директории, в которую установлен фреймворк, класс `yii\webRequest` может быть загружен
Если вы используете сторонние библиотеки, такие как Zend Framework, вы можете также определить псевдоним пути `@Zend`, автоматически. Если вы используете сторонние библиотеки, например, из Zend Framework, вы можете определить псевдоним
который соответствует установочной папке фреймворка. Единожды сделав это, Yii будет способен автоматически загружать любой класс пути `@Zend` как директорию, в которую установлен этот фреймворк. После этого Yii будет способен автоматически загружать
Zend Framework. любой класс Zend Framework.
Более детальная информация о конфигурациях представлена в разделе [Псевдонимы пути](concept-aliases.md). Подробнее о псевдонимах пути можно узнать из раздела «[Псевдонимы пути](concept-aliases.md)».
Представления Представления
------------- -----------
Одним из основных изменений в Yii2 является то, что специальная переменная `$this` в представлении, больше не соответствует Одним из основных изменений в Yii 2 является то, что специальная переменная `$this` в представлении, больше не соответствует
текущему контроллеру или виджету. Вместо этого, `$this` теперь соответствует объекту *представления*, новой возможности текущему контроллеру или виджету. Вместо этого, `$this` теперь соответствует объекту *представления*, новой возможности
введенной в версии 2.0. Объект представления имеет тип [[yii\web\View]], который представляет собой часть *представление* в введённой в версии 2.0. Объект представления имеет тип [[yii\web\View]], который представляет собой часть *view* в
шаблоне проектирования MVC. Если вы хотите получить доступ к контроллеру или виджету, то используйте выражение `$this->context`. шаблоне проектирования MVC. Если вы хотите получить доступ к контроллеру или виджету, используйте выражение `$this->context`.
Для рендеринга частичных представлений, теперь используется метод `$this->render()`, а не `$this->renderPartial()`. Для рендеринга частичных представлений теперь используется метод `$this->render()`, а не `$this->renderPartial()`.
Результат вызова метода `render` теперь должен быть выведен напрямую, т. к `render` возвращает результат рендеринга, а не Результат вызова метода `render` теперь должен быть выведен напрямую, так как `render` возвращает результат рендеринга,
отображает его сразу. Например, а не отображает его сразу:
```php ```php
echo $this->render('_item', ['item' => $item]); echo $this->render('_item', ['item' => $item]);
``` ```
Кроме использования PHP в качестве основного шаблонизатора, Yii 2.0 также включает официальные расширения для основных популярных Кроме использования PHP в качестве основного шаблонизатора, Yii 2.0 также предоставляет официальные расширения для двух
шаблонизаторов: Smarty и Twig. Шаблонизатор Prado больше не поддерживается. Для использования данных шаблонизаторов, вам необходимо популярных шаблонизаторов: Smarty и Twig. Шаблонизатор Prado больше не поддерживается. Для использования данных
настроить компонент приложения `view` с помощью указания свойств [[yii\base\View::$renderers|View::$renderers]]. шаблонизаторов необходимо настроить компонент приложения `view` задав свойство [[yii\base\View::$renderers|View::$renderers]].
Подробнее об этом можно прочитать в разделе «[Шаблонизаторы](tutorial-template-engines.md)».
Более детальная информация представлена в разделе [Шаблонизаторы](tutorial-template-engines.md).
Модели Модели
------ ------
Yii 2.0 использует основной класс [[yii\base\Model]] для моделей, аналогичный классу `CModel` в версии 1.1. Yii 2.0 использует в качестве базового класса для моделей [[yii\base\Model]], аналогичный классу `CModel` в версии 1.1.
Класс `CFormModel` более не поддерживается. Вместо этого, для создания модели формы в Yii 2.0 вы должны Класс `CFormModel` удалён. Вместо него для создания модели формы в Yii 2.0 вы должны напрямую наследоваться от [[yii\base\Model]].
напрямую наследоваться от класса [[yii\base\Model]].
В Yii 2.0 появился новый метод [[yii\base\Model::scenarios()|scenarios()]] для объявления поддерживаемых сценариев, Появился новый метод [[yii\base\Model::scenarios()|scenarios()]] для объявления поддерживаемых сценариев,
и для обозначения в каком сценарии атрибуты должны проверяться, считаться безопасными и т. п. Например, и для обозначения в каком сценарии атрибуты должны проверяться, считаться безопасными и т.п. Например,
```php ```php
public function scenarios() public function scenarios()
...@@ -200,14 +200,14 @@ public function scenarios() ...@@ -200,14 +200,14 @@ public function scenarios()
В большинстве случаев вам не нужно переопределять метод [[yii\base\Model::scenarios()|scenarios()]], если метод [[yii\base\Model::rules()|rules()]] В большинстве случаев вам не нужно переопределять метод [[yii\base\Model::scenarios()|scenarios()]], если метод [[yii\base\Model::rules()|rules()]]
полностью указывает все существующие сценарии, и если нет надобности в объявлении атрибутов небезопасными. полностью указывает все существующие сценарии, и если нет надобности в объявлении атрибутов небезопасными.
Более детальная информация представлена в разделе [Модели](structure-models.md). Более детальная информация представлена в разделе «[Модели](structure-models.md)».
Контроллеры Контроллеры
----------- -----------
В качестве базового класса для контроллеров в Yii 2.0 используется [[yii\web\Controller]], аналогичный `CWebController` в Yii 1.1. В качестве базового класса для контроллеров в Yii 2.0 используется [[yii\web\Controller]], аналогичный `CWebController`
Базовым классом для всех действий является [[yii\base\Action]]. в Yii 1.1. Базовым классом для всех действий является [[yii\base\Action]].
Одним из основных изменений является то, что действие контроллера теперь должно вернуть результат вместо того, чтобы Одним из основных изменений является то, что действие контроллера теперь должно вернуть результат вместо того, чтобы
напрямую выводить его: напрямую выводить его:
...@@ -224,7 +224,7 @@ public function actionView($id) ...@@ -224,7 +224,7 @@ public function actionView($id)
} }
``` ```
Более детальная информация представлена в разделе [Контроллеры](structure-controllers.md). Более детальная информация представлена в разделе «[Контроллеры](structure-controllers.md)».
Виджеты Виджеты
...@@ -252,7 +252,7 @@ $form = ActiveForm::begin([ ...@@ -252,7 +252,7 @@ $form = ActiveForm::begin([
ActiveForm::end(); ActiveForm::end();
``` ```
Более детальная информация представлена в разделе [Виджеты](structure-widgets.md). Более детальная информация представлена в разделе «[Виджеты](structure-widgets.md)».
Темы Темы
...@@ -261,11 +261,11 @@ ActiveForm::end(); ...@@ -261,11 +261,11 @@ ActiveForm::end();
В Yii 2.0 темы работают совершенно по-другому. Теперь они основаны на механизме сопоставления путей исходного файла В Yii 2.0 темы работают совершенно по-другому. Теперь они основаны на механизме сопоставления путей исходного файла
представления с темизированным файлом. Например, если используется сопоставление путей `['/web/views' => '/web/themes/basic']`, представления с темизированным файлом. Например, если используется сопоставление путей `['/web/views' => '/web/themes/basic']`,
то темизированная версия файла представления `/web/views/site/index.php` будет находится в `/web/themes/basic/site/index.php`. то темизированная версия файла представления `/web/views/site/index.php` будет находится в `/web/themes/basic/site/index.php`.
По этой причине, темы могут быть применены к любому файлу представления, даже к представлению, отрендеренному внутри контекста По этой причине темы могут быть применены к любому файлу представления, даже к представлению, отрендеренному внутри контекста
контроллера или виджета. Также, больше не существует компонента `CThemeManager`. Вместо этого, `theme` является конфигурируемым контроллера или виджета. Также, больше не существует компонента `CThemeManager`. Вместо этого, `theme` является конфигурируемым
свойством компонента приложения `view`. свойством компонента приложения `view`.
Более детальная информация представлена в разделе [Темизация](output-theming.md). Более детальная информация представлена в разделе «[Темизация](output-theming.md)».
Консольные приложения Консольные приложения
...@@ -280,19 +280,19 @@ ActiveForm::end(); ...@@ -280,19 +280,19 @@ ActiveForm::end();
Yii 2.0 поддерживает автоматическую генерацию справочной информации из блоков комментариев. Yii 2.0 поддерживает автоматическую генерацию справочной информации из блоков комментариев.
Более детальная информация представлена в разделе [Консольные команды](tutorial-console.md). Более детальная информация представлена в разделе «[Консольные команды](tutorial-console.md)».
I18N I18N
---- ----
В Yii 2.0 были убраны встроенные форматтеры времени и чисел, в пользу [PECL intl PHP расширения](http://pecl.php.net/package/intl). В Yii 2.0 встроенные форматтеры времени и чисел были убраны в пользу [PECL расширения PHP intl](http://pecl.php.net/package/intl).
Перевод сообщений теперь осуществляется через компонент приложения `i18n`. Данный компонент управляет множеством Перевод сообщений теперь осуществляется через компонент приложения `i18n`. Данный компонент управляет множеством
исходных хранилищ сообщений, что позволяет вам использовать разные хранилища для исходных сообщений в зависимости исходных хранилищ сообщений, что позволяет вам использовать разные хранилища для исходных сообщений в зависимости
от категории сообщения. от категории сообщения.
Более детальная информация представлена в разделе [Интернационализация](tutorial-i18n.md). Более детальная информация представлена в разделе «[Интернационализация](tutorial-i18n.md)».
Фильтры действий Фильтры действий
...@@ -316,7 +316,7 @@ public function behaviors() ...@@ -316,7 +316,7 @@ public function behaviors()
} }
``` ```
Более детальная информация представлена в разделе [Фильтры](structure-filters.md). Более детальная информация представлена в разделе «[Фильтры](structure-filters.md)».
Ресурсы Ресурсы
...@@ -324,14 +324,14 @@ public function behaviors() ...@@ -324,14 +324,14 @@ public function behaviors()
В Yii 2.0 представлена новая возможность *связка ресурсов*, которая заменяет концепт пакетов скриптов в Yii 1.1. В Yii 2.0 представлена новая возможность *связка ресурсов*, которая заменяет концепт пакетов скриптов в Yii 1.1.
Связка ресурсов - это коллекция файлов ресурсов (например, Javascript файлы, CSS файлы, файлы изображений, и т. п.) в Связка ресурсов — это коллекция файлов ресурсов (например, JavaScript файлы, CSS файлы, файлы изображений, и т.п.) в
определенной папке. Каждая связка ресурсов представлена классом, унаследованным от [[yii\web\AssetBundle]]. определенной директории. Каждая связка ресурсов представлена классом, унаследованным от [[yii\web\AssetBundle]].
Связка ресурсов становится доступной через веб, с помощью регистрации ее методом [[yii\web\AssetBundle::register()]]. Связка ресурсов становится доступной через веб после её регистрации методом [[yii\web\AssetBundle::register()]].
В отличие от Yii 1.1, страница, регистрирующая связку ресурсов, автоматически будет содержать ссылки на Javascript и CSS В отличие от Yii 1.1, страница, регистрирующая связку ресурсов, автоматически будет содержать ссылки на JavaScript и CSS
файлы, указанные в связке. файлы, указанные в связке.
Более детальная информация представлена в разделе [Ресурсы](structure-assets.md). Более детальная информация представлена в разделе «[Ресурсы](structure-assets.md)».
Хелперы Хелперы
...@@ -345,14 +345,14 @@ public function behaviors() ...@@ -345,14 +345,14 @@ public function behaviors()
* [[yii\helpers\FileHelper]] * [[yii\helpers\FileHelper]]
* [[yii\helpers\Json]] * [[yii\helpers\Json]]
Более детальная информация представлена в разделе [Хелперы](helper-overview.md). Более детальная информация представлена в разделе «[Хелперы](helper-overview.md)».
Формы Формы
----- -----
Yii 2.0 вводит новое понятие *поле* для построения форм с помощью [[yii\widgets\ActiveForm]]. Поле - это Yii 2.0 вводит новое понятие *поле* для построения форм с помощью [[yii\widgets\ActiveForm]]. Поле это
контейнер, содержащий лейбл, поле ввода, сообщение об ошибке и/или вспомогательный текст. контейнер, содержащий подпись, поле ввода, сообщение об ошибке и/или вспомогательный текст.
Поле представлено объектом [[yii\widgets\ActiveField|ActiveField]]. Используя поля, вы можете строить Поле представлено объектом [[yii\widgets\ActiveField|ActiveField]]. Используя поля, вы можете строить
формы гораздо проще чем это было раньше: формы гораздо проще чем это было раньше:
...@@ -366,7 +366,7 @@ Yii 2.0 вводит новое понятие *поле* для построе ...@@ -366,7 +366,7 @@ Yii 2.0 вводит новое понятие *поле* для построе
<?php yii\widgets\ActiveForm::end(); ?> <?php yii\widgets\ActiveForm::end(); ?>
``` ```
Более детальная информация представлена в разделе [Работа с формами](input-forms.md). Более детальная информация представлена в разделе «[Работа с формами](input-forms.md)».
Построитель запросов Построитель запросов
...@@ -374,7 +374,7 @@ Yii 2.0 вводит новое понятие *поле* для построе ...@@ -374,7 +374,7 @@ Yii 2.0 вводит новое понятие *поле* для построе
В версии 1.1, построение запроса было разбросано среди нескольких классов, включая `CDbCommand`, В версии 1.1, построение запроса было разбросано среди нескольких классов, включая `CDbCommand`,
`CDbCriteria`, и `CDbCommandBuilder`. В Yii 2.0 запрос к БД представлен в рамках объекта [[yii\db\Query|Query]], `CDbCriteria`, и `CDbCommandBuilder`. В Yii 2.0 запрос к БД представлен в рамках объекта [[yii\db\Query|Query]],
который может быть превращен в SQL выражение с помощью [[yii\db\QueryBuilder|QueryBuilder]]. Например, который может быть превращён в SQL выражение с помощью [[yii\db\QueryBuilder|QueryBuilder]]. Например,
```php ```php
$query = new \yii\db\Query(); $query = new \yii\db\Query();
...@@ -389,17 +389,18 @@ $rows = $command->queryAll(); ...@@ -389,17 +389,18 @@ $rows = $command->queryAll();
Лучшим способом использования данных методов является работа с [Active Record](db-active-record.md). Лучшим способом использования данных методов является работа с [Active Record](db-active-record.md).
Более детальная информация представлена в разделе [Построитель запросов](db-query-builder.md). Более детальная информация представлена в разделе «[Построитель запросов](db-query-builder.md)».
Active Record Active Record
------------- -------------
В Yii 2.0 внесено множество изменений в работу [Active Record](db-active-record.md). Два основных из них, включают в себя В Yii 2.0 внесено множество изменений в работу [Active Record](db-active-record.md). Два основных из них включают в себя
построение запросов и работу со связями. построение запросов и работу со связями.
Класс `CDbCriteria` в версии 1.1 был заменен [[yii\db\ActiveQuery]] в Yii 2.0. Этот класс наследуется от [[yii\db\Query]] и таким Класс `CDbCriteria` версии 1.1 был заменен [[yii\db\ActiveQuery]]. Этот класс наследуется от [[yii\db\Query]] и таким
образом получает все методы необходимые для построения запроса. Для построения запроса вам следует вызвать метод [[yii\db\ActiveRecord::find()]]: образом получает все методы, необходимые для построения запроса. Чтобы начать строить запрос следует вызвать метод
[[yii\db\ActiveRecord::find()]]:
```php ```php
// Получаем всех *активных* клиентов и сортируем их по ID // Получаем всех *активных* клиентов и сортируем их по ID
...@@ -410,8 +411,8 @@ $customers = Customer::find() ...@@ -410,8 +411,8 @@ $customers = Customer::find()
``` ```
Для объявления связи следует просто объявить геттер, который возвращает объект [[yii\db\ActiveQuery|ActiveQuery]]. Для объявления связи следует просто объявить геттер, который возвращает объект [[yii\db\ActiveQuery|ActiveQuery]].
Имя свойства, определенное геттером представляет собой название связи. Например, следующий код объявляет связь Имя свойства, определённое геттером, представляет собой название связи. Например, следующий код объявляет связь
`orders` (в версии 1.1, вам нужно было бы объявить связи в одном центральном месте - `relations()`): `orders` (в версии 1.1, вам нужно было бы объявить связи в одном месте — методе `relations()`):
```php ```php
class Customer extends \yii\db\ActiveRecord class Customer extends \yii\db\ActiveRecord
...@@ -424,25 +425,27 @@ class Customer extends \yii\db\ActiveRecord ...@@ -424,25 +425,27 @@ class Customer extends \yii\db\ActiveRecord
``` ```
Теперь вы можете использовать выражение `$customer->orders` для получения всех заказов клиента из связанной таблицы. Вы также Теперь вы можете использовать выражение `$customer->orders` для получения всех заказов клиента из связанной таблицы. Вы также
можете использовать следующий код, чтобы применить нужные условия "на лету": можете использовать следующий код, чтобы применить нужные условия «на лету»:
```php ```php
$orders = $customer->getOrders()->andWhere('status=1')->all(); $orders = $customer->getOrders()->andWhere('status=1')->all();
``` ```
Yii 2.0 осуществляет жадную загрузку (eager loading) связи по другому, в отличие от версии 1.1. В частности, в версии 1.1 для Yii 2.0 осуществляет жадную загрузку связи не так, как это было в 1.1. В частности, в версии 1.1 для выбора данных из
выбора данных из основной и связанной таблиц будет использован запрос JOIN. В Yii 2.0 будут выполнены два запроса без использования JOIN: основной и связанной таблиц будет использован запрос JOIN. В Yii 2.0 будут выполнены два запроса без использования JOIN:
первый запрос возвращает данные для основной таблицы, а второй - для связанной, с помощью фильтрации по первичным ключами основной таблицы. первый запрос возвращает данные для основной таблицы, а второй, осуществляющий фильтрацию по первичным ключами основной
таблицы — для связанной.
Вместо того, чтобы возвращать объекты [[yii\db\ActiveRecord|ActiveRecord]], вы можете использовать метод [[yii\db\ActiveQuery::asArray()|asArray()]] Вместо того, чтобы при выборке большого количества записей возвращать объекты [[yii\db\ActiveRecord|ActiveRecord]], вы
при построении запроса, для выборки большого количества записей. Это заставит вернуть результат запроса в качестве массива, что можете использовать в построении запроса метод [[yii\db\ActiveQuery::asArray()|asArray()]]. Это заставит вернуть
может существенно снизить время, нужное ЦПУ и память, при большом количестве записей. Например: результат запроса в виде массива, что при большом количестве записей может существенно снизить затрачиваемое процессорное
время и объём потребляемой памяти. Например:
```php ```php
$customers = Customer::find()->asArray()->all(); $customers = Customer::find()->asArray()->all();
``` ```
Еще одно изменение связано с тем, что вы больше не можете определять значения по-умолчанию в качестве свойств. Ещё одно изменение связано с тем, что вы больше не можете определять значения по-умолчанию через public свойства.
Вы должны установить их в методе `init` вашего класса, если это требуется. Вы должны установить их в методе `init` вашего класса, если это требуется.
```php ```php
...@@ -453,22 +456,54 @@ public function init() ...@@ -453,22 +456,54 @@ public function init()
} }
``` ```
Также в версии 1.1 были некоторые проблемы с переопределением конструктора ActiveRecord. Данные проблемы не присутствуют Также в версии 1.1 были некоторые проблемы с переопределением конструктора ActiveRecord. Данные проблемы отсутствуют
в версии 2.0. Обратите внимание, что при добавлении параметров в конструктор, вам возможно понадобится переопределить метод в версии 2.0. Обратите внимание, что при добавлении параметров в конструктор, вам, возможно, понадобится переопределить метод
[[yii\db\ActiveRecord::instantiate()]]. Переопределение может не потребоваться, если параметры, передаваемые в конструктор будут [[yii\db\ActiveRecord::instantiate()]].
иметь значения по-умолчанию, например `null`.
Существует также множество других улучшений в ActiveRecord. Подробнее о них можно узнать в разделе
«[Active Record](db-active-record.md)».
Существует также множество других улучшений в ActiveRecord. Более детальная информация о конфигурация представлена в разделе [Active Record](db-active-record.md). Поведения Active Record
-----------------------
В версии 2.0 отсутствует базовый класс для поведений `CActiveRecordBehavior`. Если вам необходимо создать поведение для
Active Record, стоит наследовать его класс напрямую от `yii\base\Behavior`. Если поведение должно реагировать на какие-либо
события, необходимо перекрыть метод `events()` следующим образом:
```php
namespace app\components;
use yii\db\ActiveRecord;
use yii\base\Behavior;
class MyBehavior extends Behavior
{
// ...
public function events()
{
return [
ActiveRecord::EVENT_BEFORE_VALIDATE => 'beforeValidate',
];
}
public function beforeValidate($event)
{
// ...
}
}
```
Компонент приложения `user` User и IdentityInterface
--------------------------- ---------------------------
Класс `CWebUser` в версии 1.1 теперь заменен классом [[yii\web\User]], а также больше не существует класса `CUserIdentity`. Класс `CWebUser` из версии 1.1 теперь заменён классом [[yii\web\User]]. Также больше не существует класса `CUserIdentity`.
Вместо этого, вы должны предоставить реализацию интерфейса [[yii\web\IdentityInterface]], что гораздо проще в использовании. Вы должны реализовать интерфейс [[yii\web\IdentityInterface]], что гораздо проще. Пример реализации представлен в шаблоне
приложения advanced.
Более детальная информация представлена в разделах [Аутентификация](security-authentication.md), [Авторизация](security-authorization.md) Более подробная информация представлена в разделах «[Аутентификация](security-authentication.md)»,
и [Шаблон приложения advanced](tutorial-advanced-app.md). «[Авторизация](security-authorization.md)» и «[Шаблон приложения advanced](tutorial-advanced-app.md)».
Разбор и генерация URL Разбор и генерация URL
...@@ -476,7 +511,7 @@ public function init() ...@@ -476,7 +511,7 @@ public function init()
Работа с URL в Yii 2.0 аналогична той, что была в версии 1.1. Основное изменение заключается в том, что теперь Работа с URL в Yii 2.0 аналогична той, что была в версии 1.1. Основное изменение заключается в том, что теперь
поддерживаются дополнительные параметры. Например, если у вас имеется правило, объявленное следующим образом, то поддерживаются дополнительные параметры. Например, если у вас имеется правило, объявленное следующим образом, то
оно совпадет с `post/popular` и `post/1/popular`. В версии 1.1, вам пришлось бы использовать два правила, для получения оно совпадет с `post/popular` и `post/1/popular`. В версии 1.1, вам пришлось бы использовать два правила, для достижения
того же результата. того же результата.
```php ```php
...@@ -487,9 +522,10 @@ public function init() ...@@ -487,9 +522,10 @@ public function init()
] ]
``` ```
Более детальная информация представлена в разделе [Разбор и генерация URL](runtime-url-handling.md). Более детальная информация представлена в разделе «[Разбор и генерация URL](runtime-url-handling.md)».
Использование Yii 1.1 вместе с 2.x Использование Yii 1.1 вместе с 2.x
---------------------------------- ----------------------------------
Информация об использовании кода для Yii 1.1 вместе с Yii 2.0 представлена в разделе [Одновременное использование Yii 1.1 и 2.0](extend-using-v1-v2.md). Информация об использовании кода для Yii 1.1 вместе с Yii 2.0 представлена в разделе
«[Одновременное использование Yii 1.1 и 2.0](extend-using-v1-v2.md)».
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment