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



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

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

Обновлено 16 апреля 2018 - 16:57  Отправлено 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 написано.



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

Отправлено 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
  • Пользователь
  • 851 сообщений
  • Репутация: 164

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

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

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

 

 0db3c0ac39cd.jpg

 

 

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

 

common/config/main-local.php
 

  • 0

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

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

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

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

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


  • 0

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



#5 pozitron123
pozitron123
  • Пользователь
  • 851 сообщений
  • Репутация: 164

Отправлено 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 188 сообщений
  • Репутация: 206

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

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

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

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

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

 

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


  • 0

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





Похожие темы
  Название темы Автор Статистика Последнее сообщение

Пользователь месяца
albedo albedo 1-й за Май
Очков активности: 198 5 тем, 29 сообщений, 3 балла репутации
Сайт: online24news.ru
ТОП самых активных за этот месяц
  • Фотография maks200
    #1

    maks200
    Очков активности: 6 1 тема, 1 сообщение, 1 балл репутации

  • Фотография NewBlade
    #2

    NewBlade
    Очков активности: 6 1 тема, 1 сообщение, 1 балл репутации

  • Фотография Movut
    #3

    Movut (seo-aspirant.ru)
    Очков активности: 4.5 1 тема, 0 сообщений, 1 балл репутации

  • Фотография 1head
    #4

    1head
    Очков активности: 4.5 1 тема, 0 сообщений, 1 балл репутации

  • Фотография magnet
    #5

    magnet (rbfxdirect.com)
    Очков активности: 4.5 1 тема, 0 сообщений, 1 балл репутации

  • Фотография Zevss
    #6

    Zevss (domles43.ru)
    Очков активности: 4.5 1 тема, 0 сообщений, 1 балл репутации

  • Фотография Nik_2266999
    #7

    Nik_2266999
    Очков активности: 3 0 тем, 2 сообщения, 1 балл репутации

  • Фотография narolskay
    #8

    narolskay (ortopedicheskaja-podushka.ru)
    Очков активности: 3 0 тем, 2 сообщения, 1 балл репутации

  • Фотография wp01
    #9

    wp01
    Очков активности: 3 0 тем, 2 сообщения, 1 балл репутации

  • Фотография getsend
    #10

    getsend
    Очков активности: 3 0 тем, 2 сообщения, 1 балл репутации

  • Показать весь ТОП 10

Поддержите форум! =)
Топ 5 участников по репутации

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