/ZendDbMigrations

Zend db migrations module

Primary LanguagePHP

ZendDbMigrations

Установка

Добавьте в composer.json проекта в секцию require "eugenzor/zend-db-migrations": "dev-master"

затем выполните

php composer.phar self-update
php composer.phar update

Использование

Список добавляемых консольных комманд

db_migrations_version - возвращает номер текущей версии
db_migrations_migrate [<version>] - выполнить или откатить миграцию, номер версии необязательный параметр
db_migrations_generate - Сгенерировать каркас класса миграции

Все миграции по умолчанию будут хранится в каталоге /project/migrations/* поэтому нужно создать папку migrations или запускать команду генерации каркаса миграций с правами на запись в корневую директорию

В общем случае классы миграций должны иметь название вида Versionггггммддччммссс.php и реализовывать интерфейс ZendDbMigrations\Library\MigrationInterface

Пример класса миграции

<?php

namespace ZendDbMigrations\Migrations;

use ZendDbMigrations\Library\AbstractMigration;
use Zend\Db\Metadata\MetadataInterface;

class Version20121112230913 extends AbstractMigration {
    
    public function up(MetadataInterface $schema){
        //$this->addSql(/*Sql instruction*/);
    }
    
    public function down(MetadataInterface $schema){
        //$this->addSql(/*Sql instruction*/);
    }
}

выполнить миграцию можно двумя способами запустив команду db_migrations_migrate без параметров или с указанием версии db_migrations_migrate 20121112230913 Version20121112230913 - здесь 20121112230913 будет версией миграции