Перейти к содержимому



ЛП: миграции в yii2, работа с базой данных

#1 fedornabilkin

fedornabilkin
  • Модератор
  • 1 075 сообщений
  • Репутация: 162
0

Отправлено 06 Февраль 2018 - 22:25

Миграции - это хорошо. Миграции можно накатывать, откатывать и перезагружать.

Yii2 предоставляет хороший инструмент для работы с миграциями через консоль. Для работы с БД, необходимо настроить подключение в файле common/config/main-local.php После инициализации приложения это файл будет сгенерирован и надо только подставить свои значения (название БД, юзер, пароль). Пока используйте редактор vim, потом будем работать в PhpStorm.

 

 

Для того, чтобы создать в БД таблицу с необходимыми полями, создаем файл миграции. Переходим в корень сайта и выполняем команду:

cd /var/www/site.dev
php yii migrate/create create_news_table

yii спросит разрешения о создании файла миграции в /var/www/site.dev/console/migrations/m180206_190613_create_news_table.php (название файла будет отличаться), соглашаемся вводом команды (Y) и файл создан со следующим содержанием. Можно посмотреть командой cat /var/www/site.dev/console/migrations/m180206_190613_create_news_table.php Чтобы не набирать руками имя файла полностью, используйте часть имени файла и клавишу tab. Набрали первые символы, нажали таб и консоль подставит.

 

Спойлер

 

Теперь мы можем создать таблицу в БД, если выполним команду (отработает метод up() созданного класса)

php yii migrate

Для удаления таблицы из БД делаем откат миграции командой

php yii migrate/down

В процессе разработки часто приходится добавлять/удалять некоторые поля из существующей таблицы. Если таблица еще не заполнена строками или эти данные не важны, то можно отредактировать метод up() (добавить/удалить поле) и перезагрузить миграцию. Следующая команда сначала выполнить метод down(), а затем метод up(), таким образом, существующая таблица сначала удалиться, а затем снова будет создана.

php yii migrate/redo

Если нет возможности удалить существующую таблицу, то надо создавать еще один файл миграции, который добавит/удалит поле в таблице или сделает что-то еще.

 

Возможность использования миграций упрощает жизнь разработчику (особенно при разработке в команде), помогает вести контроль над изменением структуры базы данных и немного еще :) Подробнее о миграциях в yii2.


 

 

Сообщение отредактировал fedornabilkin: 06 Февраль 2018 - 22:44

  • 0

Надо обсудить предложение. А тут знакосчиталка считает знаки. Про Yii2 написано.



robot

robot
  • Пользователь PRO
  • 2 652 сообщений
  • Репутация: 85
Советую обратить внимание на следующее:
  1. Yii2: сортировка по вычисляемому полю
  2. Лучшие практики
  3. ЛП: Установка Yii2
  4. Не работает ЧПУ в yii2
  5. ЛП: Установка и настройка MySQL в ubuntu

#2 fedornabilkin

fedornabilkin
    Topic Starter
  • Модератор
  • 1 075 сообщений
  • Репутация: 162

Отправлено 17 Февраль 2018 - 22:31

Переходим в корень проекта и выполняем команду на создание файла миграции. Обратите внимание, что в команде можно указать поля.

cd /var/www/site.dev
php yii migrate/create create_post_table --fields=title:string,content:text,created_at:integer,updated_at:integer 

Затем идем в шторм, в директорию console\migrations\ выкачиваем файлы с сервера (правый клик Deployment->Download ...), находим файл m180217_184300_create_post_table.php (цифры в названии будут отличаться) и открываем его для ознакомления. 

Спойлер

 

Выполняем миграцию, чтобы создать таблицу с полями в БД.

php yii migrate

Консоль спросит подтверждения на выполнение миграций и перечислит файлы миграций, которые еще не были выполнены.


  • 0

Надо обсудить предложение. А тут знакосчиталка считает знаки. Про Yii2 написано.



#3 pozitron123

pozitron123
  • Пользователь
  • 519 сообщений
  • Репутация: 101

Отправлено 16 Апрель 2018 - 13:17

yii спросит разрешения о создании файла миграции

 У меня что-то не спрашивает:

 

 0db3c0ac39cd.jpg

 

 

А этот фаил у меня пустой:

 

common/config/main-local.php
 

  • 0

#4 fedornabilkin

fedornabilkin
    Topic Starter
  • Модератор
  • 1 075 сообщений
  • Репутация: 162

Отправлено 16 Апрель 2018 - 14:04

@pozitron123, Сделай php init и инициализируй Development.

А вообще он у тебя не пустой, потому что консоль ругается на то, что не может найти базу с названием yii2advanced. Это название прописывается по умолчанию.

Потом, когда настроишь шторм, можно будет заменить данные в environments/dev/common/config/main-local.php, чтобы после инициализации не изменять данные доступа.


  • 0

Надо обсудить предложение. А тут знакосчиталка считает знаки. Про Yii2 написано.



#5 pozitron123

pozitron123
  • Пользователь
  • 519 сообщений
  • Репутация: 101

Отправлено 16 Апрель 2018 - 15:31

@pozitron123, Сделай php init и инициализируй Development. А вообще он у тебя не пустой, потому что консоль ругается на то, что не может найти базу с названием yii2advanced. Это название прописывается по умолчанию. Потом, когда настроишь шторм, можно будет заменить данные в environments/dev/common/config/main-local.php, чтобы после инициализации не изменять данные доступа.
 

Я так и не понял что нужно сделать запустил php init и что дальше?


  • 0

#6 fedornabilkin

fedornabilkin
    Topic Starter
  • Модератор
  • 1 075 сообщений
  • Репутация: 162

Отправлено 16 Апрель 2018 - 16:57

@pozitron123,  так в консоль смотри и делай, что она предлагает. Там надо будет нажать 0 и потом y.

Сначала выбираешь dev или prod, а потом подтверждаешь свой выбор. На локалке всегда выбираешь Development, чтобы можно было смотреть логи, запросы в БД, отправляемые письма и т.д. Плюс подробный стэк, при возникновении ошибок.

На удаленном серваке всегда выбираешь Production, чтобы пользователи не видели подробностей при ошибках и т.д.

Соответственно, после инициализации, в зависимости от режима (dev или prod), сгенерируются разные файлы конфигурации. Шаблоны этих файлов лежат в environments/*

 

Третий раз уже об этом пишу!


  • 0

Надо обсудить предложение. А тут знакосчиталка считает знаки. Про Yii2 написано.




Оформление форума – IPBSkins.ru