Миграции Doctrine2 переносятся вниз и переносятся из браузера, а не из командной строки - PullRequest
38 голосов
/ 09 марта 2012

Я использую миграции Doctrine2.Мне нужны ответы на некоторые вопросы о моих сомнениях, я не могу найти хорошее решение в документации

Я использую:

  doctrine migrations:diff // generate migrations files
  doctrine migrations:migrate // migrates up to new version
  1. Как я могу перейти вниз?указание предыдущей версии не сработало (в ней ничего не сказано, например, миграция доктрины: миграция Version20120211163332:

    Migrating up to Version20120211163332 from 20120309112058
    
    [Doctrine\DBAL\Migrations\MigrationException]  
    Could not find any migrations to execute.      
    

    Но это не так, должно быть и так!

  2. Если мне нужно обновить БД, возможно ли добавить несколько SQL-запросов в дополнение (изменить некоторые данные, связанные с другими)? Я не пробовал еще, так как не работает down :((

  3. Есть ли какой-либо способ использовать команду migrate в двух словах браузера? У меня есть sw на общем хостинге без консольного доступа, поэтому мне нужна эта функция, вместо того, чтобы копировать запросы по одному: D в phpMyAdmin

Ответы [ 4 ]

89 голосов
/ 21 декабря 2012

При желании вы можете вручную указать версию, на которую хотите выполнить миграцию:

 php doctrine.php migrations:migrate YYYYMMDDHHMMSS

или выполнить миграцию вверх / вниз

php doctrine.php migrations:execute YYYYMMDDHHMMSS  --down
php doctrine.php migrations:execute YYYYMMDDHHMMSS  --up

Вы можете найти ГГГГММДДЧЧММСС, используя:

php doctrine.php migrations:status
>> Current Version:           2012-12-20 23:38:47 (20121220233847)
>> Latest Version:            2012-12-20 23:38:47 (20121220233847)
26 голосов
/ 12 июня 2012

Я видел этот документ на сайте Symfony: http://symfony.com/doc/current/bundles/DoctrineMigrationsBundle/index.html#usage

Существует doctrine:migrations:execute, который позволяет вам выполнить одну версию миграции вверх или вниз вручную ... но никогда не пробовал, извините.

Надеюсь, это поможет!

Держите нас в курсе.

10 голосов
/ 04 сентября 2013

Вот как вы можете запустить миграцию из браузера:

composer.json

{
    "require": {
        "doctrine/dbal": "*",
        "doctrine/migrations": "dev-master"
    },
    "minimum-stability": "dev",
    "autoload": {
        "psr-0": {"": "src/"}
    }
}

src / Acme / Migrations / Version1.php

<?php # src/Acme/Migrations/Version1.php
namespace Acme\Migrations;

use Doctrine\DBAL\Migrations\AbstractMigration;
use Doctrine\DBAL\Schema\Schema;

/**
 * Class Version1
 *
 * Notice that file and class names MUST be Version*.php
 *
 * @package Acme\Migrations
 */
class Version1 extends AbstractMigration
{
    public function up(Schema $schema)
    {
        $users = $schema->createTable('users');
        $users->addColumn('id', 'integer', array('unsigned' => true, 'autoincrement' => true));
        $users->addColumn('username', 'string', array('length' => 128));
        $users->addColumn('password', 'string', array('length' => 128));
        $users->setPrimaryKey(array('id'));

        // You can also add any queries
        // $this->addSql('CREATE TABLE addresses (id INT NOT NULL, street VARCHAR(255) NOT NULL, PRIMARY KEY(id)) ENGINE = InnoDB');
    }

    public function down(Schema $schema)
    {
        $schema->dropTable('users');

        //$this->addSql('DROP TABLE addresses');
    }

    // Use this functions to prepare your migrations
    //public function preUp(Schema $schema) {}
    //public function postUp(Schema $schema) {}
    //public function preDown(Schema $schema) {}
    //public function postDown(Schema $schema) {}
}

index.php

<?php # index.php
use Doctrine\DBAL\DriverManager;
use Doctrine\DBAL\Migrations\Configuration\Configuration;
use Doctrine\DBAL\Migrations\Migration;
use Doctrine\DBAL\Migrations\OutputWriter;

require_once 'vendor/autoload.php';

$nl = PHP_SAPI == 'cli' ? PHP_EOL : '<br>'; // Optional will be used for output

$to = null; // Optional integer - migrate to version, if null - will migrate to latest available version
#region Optional get argument
$index = PHP_SAPI == 'cli' ? 1 : 'to';
$arguments = PHP_SAPI == 'cli' ? $argv : $_REQUEST;
$to = isset($arguments[$index]) && filter_var($arguments[$index], FILTER_VALIDATE_INT) ? intval($arguments[$index]) : null;
#endregion

#region Doctrine Connection
// Silex: $app['db']
// Symfony controller: $this->get('database_connection')
$db = DriverManager::getConnection(array(
    'dbname' => 'doctine_migrations',
    'user' => 'root',
    'password' => 'root',
    'host' => 'localhost',
    'driver' => 'pdo_mysql',
    'charset' => 'utf8',
    'driverOptions' => array(
        PDO::MYSQL_ATTR_INIT_COMMAND => 'SET NAMES utf8'
    )
));
#endregion

#region Config
$config = new Configuration($db /*, new OutputWriter(function ($message) { echo $message . PHP_EOL; })*/); // OutputWriter is optional and by default do nothing, accepts closure for writing logs

//$config->setName('My Migrations'); // Optional name for your migrations
$config->setMigrationsTableName('version'); // Table name that will store migrations log (will be created automatically, default name is: doctrine_migration_versions)
$config->setMigrationsNamespace('Acme\\Migrations'); // Namespace of your migration classes, do not forget escape slashes, do not add last slash
$config->setMigrationsDirectory('src/Acme/Migrations'); // Directory where your migrations are located
$config->registerMigrationsFromDirectory($config->getMigrationsDirectory()); // Load your migrations
#endregion

$migration = new Migration($config); // Create Migration based on provided configuration

$versions = $migration->getSql($to); // Retrieve SQL queries that should be run to migrate you schema to $to version, if $to == null - schema will be migrated to latest version

#region Some dummy output
foreach ($versions as $version => $queries) {
    echo 'VERSION: ' . $version . $nl;
    echo '----------------------------------------------' . $nl . $nl;

    foreach ($queries as $query) {
        echo $query . $nl . $nl;
    }

    echo $nl . $nl;
}
#endregion

try {
    $migration->migrate($to); // Execute migration!
    echo 'DONE' . $nl;
} catch (Exception $ex) {
    echo 'ERROR: ' . $ex->getMessage() . $nl;
}

Теперь вы можете:

Запустить его из консоли:

php index.php - перейдет на более позднюю версию

php index.php 2 - перейдет на версию 2 (если текущая версия больше - будет перенесена вниз

Запуск из веб-браузера:

http://localhost/index.php и http://localhost/index.php?to=2 сделают то же самое.

3 голосов
/ 07 февраля 2019

Если вы хотите выполнить миграцию на 1 шаг вниз, вы можете использовать этот синтаксис:

./doctrine migrations:migrate prev

Для перехода к первой миграции:

./doctrine migrations:migrate first

Чтобы перейти к следующей миграции:

./doctrine migrations:migrate next

Источник: https://www.doctrine -project.org / projects / doctrine-migrations / en / 1.8 / reference / manage_migrations.html # manage-migrations

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...