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


Пользователь месяца
BLIK BLIK 1-й за Февраль
Очков активности: 1228 0 тем, 63 сообщения, 13 баллов репутации
ТОП самых активных за этот месяц
  • Фотография Андрей WPMasterKZ
    #1

    Андрей WPMasterKZ (wpmaster.kz)
    Очков активности: 1596 Вне конкурса за определение пользователя месяца

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

    ShowPrint (ShowPrint.ru)
    Очков активности: 874.5 1 тема, 50 сообщений, 11 баллов репутации

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

    magnet (rbfxdirect.com)
    Очков активности: 451.5 Вне конкурса за определение пользователя месяца

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

    Megoydagi
    Очков активности: 333 8 тем, 50 сообщений, 3 балла репутации

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

    maxnik (konovalovpavel.ru)
    Очков активности: 279 2 темы, 56 сообщений, 3 балла репутации

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

    pozitron123
    Очков активности: 202.5 5 тем, 30 сообщений, 3 балла репутации

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

    BLIK
    Очков активности: 142.5 Вне конкурса за определение пользователя месяца

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

    OlgaGetman
    Очков активности: 117 Вне конкурса за определение пользователя месяца

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

    WGN (worldgamenews.com)
    Очков активности: 108 0 тем, 36 сообщений, 2 балла репутации

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

    Ixman (o5cat.ru)
    Очков активности: 57 Вне конкурса за определение пользователя месяца

  • Показать весь ТОП 10
Поддержите форум! =)
Апдейты
  • Яндекс ИКС: 26.02.2019
  • Яндекс выдача: 21.03.2019
Топ 5 участников по репутации


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

#1 fedornabilkin

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

Отправлено 06 February 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 February 2018 - 22:44

  • 0

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



#2 fedornabilkin

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

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

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

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

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

 

 0db3c0ac39cd.jpg

 

 

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

 

common/config/main-local.php
 

  • 0

#4 fedornabilkin

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

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

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

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

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


  • 0

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



#5 pozitron123

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

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

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

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


  • 0

#6 fedornabilkin

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

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

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

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

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

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

 

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


  • 0

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





Похожие темы

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

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