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 出错,也方便团队协同开发。只要记得每次改结构前先写迁移,后续部署就能一键同步。不复杂但容易忽略细节,比如字段长度或是否允许为空。
以上就是如何使用Laravel进行数据库迁移_Laravel数据库迁移操作指南的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1337872.html
微信扫一扫
支付宝扫一扫