在CakePHP中进行数据库迁移主要涉及到以下几个步骤:
确保已经安装了CakePHP框架并正确配置了数据库连接信息。
在src/Template/App/Config/database.php
文件中,确保已经定义了所有需要的数据表和字段。例如:
'connections' => [
'default' => [
// ...
'fields' => [
'id' => ['type' => 'integer'],
'name' => ['type' => 'string', 'length' => 255, 'null' => false],
'email' => ['type' => 'string', 'length' => 255, 'null' => false, 'unique' => true],
// ...
],
// ...
],
],
bin/cake bake migration CreateTableUsers --table Users
这将在src/Template/Migrations
目录下创建一个新的迁移文件,例如20210901000000_create_table_users.php
。文件名中的时间戳会根据当前时间自动生成。
<?php
namespace App\Model\Table;
use Cake\ORM\Table;
class UsersTable extends Table
{
// ...
}
在文件中,找到up()
方法,然后使用CakePHP的ORM方法来定义数据表结构。例如,为上面定义的UsersTable
添加一个字段:
public function up()
{
$this->addColumn('age', [
'type' => 'integer',
'null' => false,
'default' => 0,
]);
}
同样,你可以在down()
方法中定义如何回滚这个迁移。
bin/cake bake migrate
这将根据你在迁移文件中定义的更改更新数据库结构。
bin/cake bake migrate revert ALL
这将撤销所有未提交的迁移。如果你想回滚特定的迁移,可以使用:
bin/cake bake migrate revert <migration_file_name>
将<migration_file_name>
替换为你要回滚的迁移文件名。