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是一种功能强大的网络程序设计语言,而且易学易用,移植性和可扩展性也都非常优秀,本书将为读者详细介绍PHP编程。 全书分为预备篇、开始篇和加速篇三大部分,共9章。预备篇主要介绍一些学习PHP语言的预备知识以及PHP运行平台的架设;开始篇则较为详细地向读者介绍PKP语言的基本语法和常用函数,以及用PHP如何对MySQL数据库进行操作;加速篇则通过对典型实例的介绍来使读者全面掌握PHP。 本书
-
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 出错,也方便团队协同开发。只要记得每次改结构前先写迁移,后续部署就能一键同步。不复杂但容易忽略细节,比如字段长度或是否允许为空。









