Laravel通过迁移实现数据库版本控制,使用Artisan命令生成迁移文件,如make:migration创建表或修改结构,文件中up()定义变更、down()回滚;通过migrate执行迁移,rollback或reset回滚,支持字段类型、索引及外键约束,便于团队协作与部署同步。
在 Laravel 中,数据库迁移是一种管理数据库结构变更的便捷方式。它允许你用 PHP 代码定义表结构,而不是手动执行 SQL 语句,从而实现数据库版本控制和团队协作的一致性。下面介绍如何使用 Laravel 进行数据库迁移操作。
Laravel 提供 Artisan 命令来生成迁移文件。你可以通过以下命令创建一个新的迁移:
php artisan make:migration create_users_table — 创建一个用于创建 users 表的迁移php artisan make:migration add_email_to_users — 创建一个用于修改现有表结构的迁移执行后,Laravel 会在 database/migrations 目录下生成一个带时间戳的 PHP 文件。该文件包含两个方法:up() 和 down()。
up() 用于定义数据库更改(如创建表或添加字段),down() 则用于撤销这些更改(如删除表或字段)。
在迁移文件中,可以使用 Laravel 的 Schema 构建器来定义表结构。例如,创建一个包含 name 和 email 字段的 users 表:
public function up()
{
Schema::create('users', function (Blueprint $table) {
$table->id();
$table->string('name');
$table->string('email')->unique();
$table->timestamps();
});
}
public function down()
{
Schema::dropIfExists('users');
}
如果只是修改已有表,比如添加字段:
public function up() { Schema::table('users', function (Blueprint $table) { $table->string('phone')->nullable(); }); } public function down() { Schema::table('users', function (Blueprint $table) { $table->dropColumn('phone'); }); }
编写完迁移文件后,使用以下命令将更改应用到数据库:
php artisan migrate — 执行所有未运行的迁移如果需要撤销最近一次迁移:
php artisan migrate:rollback — 回滚最后一次迁移批次php artisan migrate:rollback --step=3 — 回滚最近三次迁移若要重置所有迁移:
php artisan migrate:reset — 回滚所有迁移开发过程中,常使用:
php artisan migrate:fresh — 删除所有表并重新运行所有迁移(不会执行 rollback)php artisan migrate:refresh — 相当于 reset + migrate,适合重置数据库结构Laravel 支持丰富的字段类型和约束方法:
$table->id(); — 创建自增主键$table->string('name', 100); — 创建 VARCHAR 字段$table->text('description'); — 创建 TEXT 字段$table->integer('age'); — 创建整数字段$table->boolean('active'); — 创建布尔字段$table->foreignId('user_id')->constrained(); — 创建外键$table->softDeletes(); — 添加软删除字段还可以添加索引:
$table->index('email') — 普通索引$table->unique('email') — 唯一索引基本上就这些。掌握迁移能让你更高效地管理数据库结构变化,避免手动写 SQL 出错,也方便团队协同开发。只要记得每次改结构前先写迁移,后续部署就能一键同步。不复杂但容易忽略细节,比如字段长度或是否允许为空。