In der folgenden Tutorial-Kolumne des thinkphp-Frameworks erfahren Sie, wie thinkPHP migrate zur Implementierung der Datenbankmigration verwendet. Ich hoffe, dass es für Freunde in Not hilfreich sein wird!
thinkPHP verwendet migrate, um die Datenbankmigration zu implementieren
das Datenbankmigrationstool von thinkPHP: topthink/think-migration
1: topthink/think-migration installieren
Beachten Sie hier, dass Sie bei der Installation von topthink/think-migration auf Ihre thinkPHP-Version achten müssen. Meine thinkPHP-Version hier ist 5.1, Sie können also Version 2.0 von topthink/ installieren. think-migration. , Version 3.0 kann nicht installiert werden, wählen Sie die für Sie geeignete Version zur Installation aus
composer require topthink/think-migration=2.0.*
Nach Abschluss der Installation führen Sie Folgendes in der Befehlszeile aus:
php think
Das Folgende zeigt an, dass die Migrationsinstallation ist erfolgreich
Zwei: Verwenden Sie topthink/think-migration, um die Datenbankmigration zu implementieren
1: Erstellen Sie eine Migrationsklasse
Ausführen in der Befehlszeile
php think migrate:create CreateUser
Nachdem die Ausführung abgeschlossen ist, erstellen wir eine Migrate-Migrationsdatei im Verzeichnis ./database/migrateions
2: Implementieren Datenbankmigration
Dokumentation zur Methodenverwendung migrieren: http://docs.org/en/latest/migrations.html
[1]: Codebeschreibung migrieren:
Es gibt drei Methoden in migrate
up: when migrate:run Execute (vorausgesetzt, die Änderungsmethode ist nicht in der Datei vorhanden)
down: Execute when migrate:rollback (vorausgesetzt, die Änderung Methode ist in der Datei nicht vorhanden)
change:migrate:run und migrate:rollback (Wenn diese Methode vorhanden ist, wird up und down nicht ausgeführt)
Im Allgemeinen lösche ich die Änderungsmethode In der Migrationsdatei werden mit der Up-Methode speziell die Vorgänge zum Hinzufügen und Aktualisieren von Tabellen und mit der Down-Methode Vorgänge zum Löschen von Tabellen und Feldern platziert.
(1) Tabelle hinzufügen:
// create the table $table = $this->table('user', ['id' => 'user_id', 'comment' => '用户表', 'engine' => 'MyISAM', '']); $table->addColumn('user_name', 'string', ['limit' => 15, 'default' => '', 'comment' => '用户名']) ->addColumn('password', 'string', ['limit' => 15, 'default' => '', 'comment' => '密码',]) ->addColumn('status', 'boolean', ['limit' => 1, 'default' => 0, 'comment' => '状态']) ->addIndex(['user_name'], ['unique' => true])//为user_name创建索引并设置唯一(唯一索引) ->addTimestamps()//默认生成create_time和update_time两个字段 ->create();
(2 ) Tabelle aktualisieren:
$this->table('user') ->addColumn('test', 'string', ['limit' => 15, 'default' => '', 'comment' => '测试'])//在user表中增加一个test字段 ->update();
(3) Tabelle löschen:
$this->table('user')->drop();
(4) Feld löschen
$this->table('user') ->removeColumn('test')//删除user表中的test字段 ->save();
[2]:Migrate-Befehl:
Es gibt drei häufig verwendete Befehle für die Migration, nämlich:
php think migrate:create CreateUser #创建一个迁移类 php think migrate:run #执行迁移 php think migrate:rollback #迁移回滚
Das obige ist der detaillierte Inhalt vonWie thinkPHP migrate verwendet, um die Datenbankmigration zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!