Phalcon - Datenbankmigration
Die Datenbankmigration ist aus folgenden Gründen wichtig:
Die Datenbankmigration hilft beim Übertragen von Daten zwischen den angegebenen Speichertypen.
Die Datenbankmigration bezieht sich auf den Kontext von webbasierten Anwendungen, die von einer Plattform auf eine andere migrieren.
Dieser Prozess findet normalerweise statt, um den Überblick über veraltete Daten zu behalten.
Phalcon führt den Datenbankmigrationsprozess folgendermaßen durch:
Step 1 - Erstellen Sie ein Projekt mit dem Namen “dbProject” im xampp/wamp Verzeichnis.
Step 2 - Konfigurieren Sie das Projekt mit der entsprechenden Datenbankkonnektivität.
<?php
/*
* Modified: preppend directory path of current file,
because of this file own different ENV under between Apache and command line.
* NOTE: please remove this comment.
*/
defined('BASE_PATH') || define('BASE_PATH', getenv('BASE_PATH') ?: realpath(dirname(__FILE__) . '/../..'));
defined('APP_PATH') || define('APP_PATH', BASE_PATH . '/app');
return new \Phalcon\Config(['database' => [
'adapter' => 'Mysql',
'host' => 'localhost',
'username' => 'root',
'password' => '',
'dbname' => 'demodb',
'charset' => 'utf8', ],
'application' => [ 'appDir' => APP_PATH . '/',
'controllersDir' => APP_PATH .
'/controllers/', 'modelsDir' => APP_PATH .
'/models/', 'migrationsDir' => APP_PATH .
'/migrations/', 'viewsDir' => APP_PATH .
'/views/','pluginsDir' => APP_PATH .
'/plugins/', 'libraryDir' => APP_PATH .
'/library/', 'cacheDir' => BASE_PATH .
'/cache/', 'baseUri' => '/dbProject/',
] ]);
Step 3- Führen Sie den Befehl zur Migration von Tabellen aus, die in der Datenbank "demodb" enthalten sind. Derzeit enthält es eine Tabelle "Benutzer".
Step 4 - Die migrierten Datenbankdateien werden im Migrationsverzeichnis im Ordner "app" gespeichert.
Somit werden die Tabellen erfolgreich migriert.
Grundlegendes zur Anatomie migrierter Dateien
Die migrierte Datei hat eine eindeutige Klasse, die erweitert wird Phalcon\Mvc\Model\MigrationKlasse. Die Migrationsklasse in Phalcon enthält die Methodenup() und down(). Dasup() Die Methode wird zum Durchführen der Migration verwendet, während die Down-Methode den Vorgang zurücksetzt.
Users.php
<?php
use Phalcon\Db\Column;
use Phalcon\Db\Index;
use Phalcon\Db\Reference;
use Phalcon\Mvc\Model\Migration;
/**
* Class UserMigration_100
*/
class UserMigration_100 extends Migration {
/**
* Define the table structure
*
* @return void
*/
public function morph() {
$this->morphTable('user', [
'columns' => [
new Column( 'Id', [
'type' => Column::TYPE_INTEGER,
'notNull' => true,
'autoIncrement' => true,
'size' => 11, 'first' => true ] ),
new Column( 'username', [
'type' => Column::TYPE_VARCHAR,
'notNull' => true,
'size' => 40,
'after' => 'Id' ] ),
new Column( 'email', [
'type' => Column::TYPE_VARCHAR,
'notNull' => true,
'size' => 40,
'after' => 'username' ] ),
new Column( 'password', [
'type' => Column::TYPE_VARCHAR,
'notNull' => true,
'size' => 10,
'after' => 'email' ] )
],
'indexes' => [new Index('PRIMARY', ['Id'], 'PRIMARY') ],
'options' => [ 'TABLE_TYPE' => 'BASE TABLE',
'AUTO_INCREMENT' => '3', 'ENGINE' => 'InnoDB',
'TABLE_COLLATION' => 'latin1_swedish_ci' ],
] );
}
/**
* Run the migrations
* * @return void
*/
public function up() {
}
/**
* Reverse the migrations
*
* @return void
*/
public function down() {
}
}
Die Klasse UserMigration_100 wie im obigen Beispiel gezeigt, enthält ein assoziatives Array mit vier Abschnitten, die -
Columns - Enthält eine Reihe von Tabellenspalten.
Indexes - Enthält eine Reihe von Tabellenindizes.
References - Beinhaltet alle referenziellen Integritätsbeschränkungen (Fremdschlüssel).
Options - Array mit einer Reihe von Optionen zur Tabellenerstellung.
Wie im obigen Beispiel gezeigt, wurde Version 1.0.0 der Datenbank erfolgreich migriert. Phalcon kann mehrere Migrationsprozesse enthalten und ausführen, je nachdem, wie der Datenbankinhalt aufbewahrt wird.