首页 > php框架 > Laravel > 正文

Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势

php中文网
发布: 2025-12-06 20:19:24
原创
291人浏览过
Laravel迁移可版本化管理数据库结构,通过Artisan命令创建、执行和回滚迁移文件,实现多环境结构同步;使用make:migration生成文件,up()定义变更、down()回滚,配合migrate等命令操作;结合Seeder填充测试数据,提升团队协作与部署稳定性。

laravel数据库迁移怎么用_laravel migration管理数据库结构的正确姿势

Laravel 的数据库迁移(Migration)功能是管理数据库结构的利器,它让你像版本控制代码一样管理数据库变更。通过命令行创建和执行迁移文件,可以轻松在不同环境中同步表结构,避免手动修改带来的不一致问题。

创建迁移文件

使用 Artisan 命令快速生成迁移文件:

php artisan make:migration create_users_table
登录后复制

如果需要附带模式定义,可加上 --create--table 参数:

  • php artisan make:migration create_posts_table --create=posts:会自动生成带有基础字段的骨架
  • php artisan make:migration add_email_to_users_table --table=users:用于修改已有表

编写迁移逻辑

每个迁移文件包含两个核心方法:up()down()

  • up():定义如何应用变更,比如创建表或添加字段
  • down():定义如何回滚变更,应与 up 方法对称

示例:创建 posts 表

public function up()
{
    Schema::create('posts', function (Blueprint $table) {
        $table->id();
        $table->string('title');
        $table->text('content');
        $table->unsignedBigInteger('user_id');
        $table->timestamps();

        $table->foreign('user_id')->references('id')->on('users')->onDelete('cascade');
    });
}

public function down()
{
    Schema::dropIfExists('posts');
}
登录后复制

执行与回滚迁移

迁移写好后,通过以下命令操作:

Shepherd Study
Shepherd Study

一站式AI学习助手平台,提供AI驱动的学习工具和辅导服务

Shepherd Study 54
查看详情 Shepherd Study
  • php artisan migrate:运行所有未执行的迁移
  • php artisan migrate:rollback:回滚最后一次迁移批次
  • php artisan migrate:refresh:先回滚全部再重新执行,适合开发重置
  • php artisan migrate:fresh:删除所有表并重新迁移,更彻底

注意:生产环境慎用 refresh 和 fresh,建议配合备份策略。

使用 Seeder 填充测试数据

迁移只管结构,数据填充可用 Seeder 配合完成。

  • 生成 Seeder:php artisan make:seeder UserSeeder
  • run() 方法中使用 Eloquent 或 DB 类插入数据
  • 运行:php artisan db:seed 或指定类:php artisan db:seed --class=UserSeeder

可在 DatabaseSeeder 中调用多个 Seeder,形成初始化流程。

基本上就这些。合理使用 Migration 能大幅提升团队协作效率和部署稳定性,关键是保持迁移文件细粒度、语义清晰,并与实际发布节奏匹配。

以上就是Laravel数据库迁移怎么用_Laravel Migration管理数据库结构的正确姿势的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号