使用迁移在 Laravel 中进行数据库架构管理:深入教程

使用迁移在 laravel 中进行数据库架构管理:深入教程

laravel 迁移是管理数据库架构更改的好方法。它们允许您对数据库结构进行版本控制,并随时间轻松回滚或修改更改。在本指南中,我们将逐步探索在 laravel 中创建、运行和回滚迁移的过程,并提供一个实践示例。

第 1 步:设置 laravel 环境

开始迁移之前,请确保已安装 laravel。您可以通过 composer 执行此操作:

composer create-project --prefer-dist laravel/laravel migration-demo

然后导航到项目文件夹:

cd migration-demo

第2步:数据库配置

要配置数据库,请在 laravel 项目中打开 .env 文件并更新数据库凭据:

db_connection=mysqldb_host=127.0.0.1db_port=3306db_database=your_database_namedb_username=your_usernamedb_password=your_password

配置数据库后,如果本地环境尚不存在,您可以创建一个新数据库。

第 3 步:创建迁移

您可以使用 artisan 命令创建新的迁移。例如,要创建用户表迁移:

php artisan make:migration create_users_table

该命令在database/migrations目录中生成一个迁移文件。文件名将包含时间戳,类似于 2024_09_13_123456_create_users_table.php。

第 4 步:定义迁移架构

打开生成的迁移文件。你会发现两个方法:up()(定义表创建)和down()(定义表如何回滚)。

创建用户表的示例:

id(); // primary key            $table->string('name');            $table->string('email')->unique();            $table->timestamp('email_verified_at')->nullable();            $table->string('password');            $table->remembertoken();            $table->timestamps(); // created at & updated at        });    }    /**     * reverse the migrations.     *     * @return void     */    public function down()    {        schema::dropifexists('users');    }}

在 up() 方法中,我们定义了 users 表的结构。 down() 方法定义了在回滚时如何删除表(即删除表)。

第 5 步:运行迁移

要运行迁移并在数据库中创建用户表,请使用以下命令:

php artisan migrate

此命令将执行所有尚未运行的迁移。您应该看到以下输出:

migrating: 2024_09_13_123456_create_users_tablemigrated:  2024_09_13_123456_create_users_table (0.45 seconds)

您可以验证用户表是否已在数据库中创建。

第 6 步:回滚迁移

要回滚最近的迁移,请使用以下命令:

php artisan migrate:rollback

这将删除用户表或最近迁移批次中定义的任何表。

要回滚多个个迁移步骤,请使用:

php artisan migrate:rollback --step=2

这将回滚最后两批迁移。

第 7 步:修改现有表

如果要修改现有表(例如添加列),请创建新的迁移:

php artisan make:migration add_phone_to_users_table --table=users

这将创建一个用于修改用户表的迁移。然后您可以定义更改:

public function up(){    schema::table('users', function (blueprint $table) {        $table->string('phone')->nullable(); // add phone column    });}public function down(){    schema::table('users', function (blueprint $table) {        $table->dropcolumn('phone'); // remove phone column    });}

运行迁移以应用更改:

php artisan migrate

第 8 步:播种数据库

laravel 还允许您使用虚拟数据为数据库播种。要创建播种机,请使用:

php artisan make:seeder userstableseeder

在位于database/seeders/userstableseeder.php的播种器文件中,您可以定义数据:

use illuminatesupportfacadesdb;use illuminatesupportfacadeshash;class userstableseeder extends seeder{    public function run()    {        db::table('users')->insert([            'name' => 'john doe',            'email' => 'john@example.com',            'password' => hash::make('password'),        ]);    }}

然后使用以下命令运行播种器:

php artisan db:seed --class=userstableseeder

您还可以在迁移过程中通过调用 databaseseeder.php 中的播种器来为数据库播种。

第 9 步:运行所有迁移和播种器

重置数据库并运行所有迁移和播种程序:

php artisan migrate:fresh --seed

此命令将删除所有表,重新运行所有迁移,并为数据库设定种子。

第 10 步:迁移最佳实践

版本控制:始终将迁移与代码一起提交到版本控制 (git)。小型迁移:将大型迁移分解为较小的迁移,以便更轻松地回滚和调试。避免更改现有迁移:如果您已经在生产中运行迁移,请创建一个新迁移来修改数据库,而不是更改现有迁移。

实践示例摘要

创建一个新的 laravel 项目。配置数据库连接的.env 文件。为用户表创建迁移。在 up() 方法中定义表模式。使用 php artisan migrate 运行迁移。通过另一个迁移添加电话列来修改用户表。根据需要回滚或重新运行迁移。使用示例数据为数据库添加种子。使用迁移有效管理数据库状态。

通过执行以下步骤,您可以使用迁移轻松管理 laravel 中的数据库架构更改。 laravel 迁移是保持数据库结构版本控制并在不同环境(如开发、登台和生产)之间同步的重要组成部分。

以上就是使用迁移在 Laravel 中进行数据库架构管理:深入教程的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1246476.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
探索 PHP 中的并发性和并行性:实践教程和技巧
上一篇 2025年12月9日 18:37:27
保护 PHP 应用程序免受 SQL 注入攻击
下一篇 2025年12月9日 18:37:34

相关推荐

  • composer require-dev和require有什么不同_Composer Require与Require-Dev区别解析

    require用于声明项目运行必需的依赖,如框架、数据库组件和第三方SDK,这些包会随项目部署到生产环境;2. require-dev用于声明仅在开发和测试阶段需要的工具,如PHPUnit、PHPStan、Faker等,不会默认部署到生产环境;3. 安装时composer install根据环境决定…

    2026年5月10日
    1000
  • 开源免费PHP工具 PHP开发效率提升利器

    推荐开源免费PHP开发工具以提升效率:VS Code、Sublime Text轻量高效,PhpStorm专业强大;调试用Xdebug、Kint、Ray;依赖管理选Composer;代码质量工具包括PHPStan、Psalm、PHP_CodeSniffer;数据库管理可用%ignore_a_1%MyA…

    2026年5月10日
    000
  • 谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧谷歌浏览器如何截图 谷歌浏览器页面截图技巧

    使用谷歌浏览器的开发者工具截图步骤:1. 按ctrl+shift+i(windows/linux)或cmd+option+i(mac)打开开发者工具。2. 点击右上角三个点,选择”更多工具”,再选择”截图”。3. 选择截取整个页面。推荐的谷歌浏览器扩展…

    2026年5月10日 用户投稿
    100
  • MySQL数据库不支持中文的解决办法

    接上一篇文章,在解决了mysql+flask环境配置问题之后,往数据库存中文字符串会报1366错误,提示不正确的字符。继而发现默认的mysql采用了latin1字符集,这种编码是不支持中文的。 如果想支持中文的话,需要设置一下mysql字符集。 众所周知utf-8是可以的,gbk也没问题,为了可扩展…

    用户投稿 2026年5月10日
    000
  • PHP多维数组到复杂XML结构的SOAP序列化实践

    本文旨在解决php多维数组向复杂soap xml结构序列化时遇到的“无法序列化结果”问题。通过深入理解soap xml的结构要求,包括命名空间和类型属性,文章将指导您如何构建符合特定xml schema的php关联数组。我们将利用`spatie/array-to-xml`库,详细演示其安装与使用方法…

    2026年5月10日
    100
  • JavaScript计算器开发:解决数值显示与初始化问题

    本教程深入探讨了使用JavaScript构建计算器时常见的数值显示异常问题,特别是由于类属性未初始化导致的`Cannot read properties of undefined`错误。我们将详细分析问题根源,并通过在构造函数中调用初始化方法来解决该问题,同时优化显示逻辑,确保计算器功能稳定且界面显…

    2026年5月10日
    000
  • NextAuth getToken 在服务端返回 null 的问题排查与解决

    问题描述 在使用 Next.js 和 NextAuth 构建应用程序时,有时需要在服务端获取用户的身份验证信息。getToken 函数是 NextAuth 提供的一个便捷方法,用于从请求中提取 JWT (JSON Web Token)。然而,在某些情况下,尤其是在使用 getServerSidePr…

    2026年5月10日
    000
  • HTML文档如何工作?如何编辑HTML格式文件?

    HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?HTML文档如何工作?如何编辑HTML格式文件?

    浏览器解析和渲染html的过程包括:1. 解析html构建dom树;2. 结合css构建渲染树;3. 布局计算元素位置;4. 绘制像素到屏幕。编辑html可使用记事本、vs code、sublime text等文本或代码编辑器,其中vs code因语法高亮、自动补全和插件生态成为主流选择。标准htm…

    2026年5月10日 用户投稿
    100
  • GolangWeb项目异常捕获与日志记录

    答案:通过中间件使用defer和recover捕获panic,结合zap等结构化日志库记录请求链路信息,为每个请求生成trace ID,实现异常捕获与可追踪日志,提升系统稳定性与可观测性。 在Go语言Web项目中,异常捕获与日志记录是保障系统稳定性和可维护性的关键环节。Go本身没有像其他语言那样的t…

    2026年5月10日
    100
  • Python官网用户调查的参与方式_Python官网反馈提交详细教程

    答案是通过访问Python官网新闻页面、邮件邀请链接或GitHub仓库提交反馈。具体为:访问官网查找用户调查公告,或点击邮件中的专属链接参与,在GitHub的cpython仓库提交技术建议,并注意如实填写问卷与保护隐私。 如果您希望参与Python官网的用户调查并提交反馈,可以通过官方指定的渠道完成…

    2026年5月10日
    300
  • Go语言连接外部MySQL数据库:DSN配置与常见错误解析

    本文详细阐述了go语言使用`go-sql-driver/mysql`驱动连接外部mysql数据库的正确方法。重点介绍了数据源名称(dsn)的规范格式,特别是主机地址部分的配置,以避免常见的“getaddrinfow: the specified class was not found.”等网络解析错…

    2026年5月10日
    000
  • Tensorflow 音乐预测

    在本文中,我展示了如何使用张量流来预测音乐风格。在我的示例中,我比较了电子音乐和古典音乐。 你可以在我的github上找到代码:https://github.com/victordalet/sound_to_partition i – 数据集 第一步,您需要创建一个数据集文件夹,并在里面…

    2026年5月10日
    000
  • 深入理解 Laravel Session::put:避免常见陷阱与实现表单限流

    本文旨在深入探讨 laravel 框架中 `session::put` 方法的正确用法及其常见误区。针对用户在实现表单提交限流时遇到的问题,详细阐述了 `session::put` 必须提供键值对的原理,并提供了如何在控制器中利用会话机制有效防止重复提交的实战代码示例。通过本文,读者将掌握 lara…

    2026年5月10日
    000
  • Voyager 中关联关系的翻译问题解决方案

    本文档旨在解决在使用 TCGVoyager 管理后台时,关联模型无法正确翻译的问题。主要针对 Laravel 项目中,使用 Voyager 1.4 版本以及 Laravel 8.0 版本,并且已经配置多语言支持的情况下,如何确保关联关系中的可翻译字段能够根据当前应用语言环境进行正确翻译。通过修改 B…

    2026年5月10日
    000
  • 学习了Python的Flask后,Go语言的Web框架该选Gin还是Beego?

    学习编程时,选择合适的框架至关重要。许多开发者在掌握Python Flask后,转向Go语言Web开发时,常常在Gin和Beego之间难以抉择。本文将深入分析,助您做出明智选择。 虽然网上搜索结果多建议使用Go原生标准库http,但实际上所有框架都是对http的封装。虽然使用http开发灵活,但工作…

    2026年5月10日
    000
  • 后缀php怎么打开_php文件打开方式与运行环境搭建指南

    要打开PHP文件需根据用途选择方式:查看代码可用文本编辑器或IDE,运行则需服务器环境。推荐新手使用XAMPP、WAMP等集成环境,将文件放入htdocs目录后访问localhost;开发者可利用PHP内置服务器,命令行执行php -S localhost:8000运行;高级用户可手动配置Apach…

    2026年5月10日
    000
  • JavaScript动态下拉菜单:实现日期选项与价格计算关联

    在现代web应用中,动态生成表单元素并使其具备交互逻辑是常见的需求。特别是在需要根据用户选择调整价格或服务参数的场景下,下拉菜单()常被用来展示一系列选项。本教程将指导您如何利用javascript动态生成一个包含日期选项的下拉菜单,并为每个选项关联一个具体的数值(如剩余天数),进而实现一个基于用户…

    2026年5月10日
    000
  • 如何在不暴露密钥的情况下,在客户端创建 Stripe Payment Link

    本文介绍了在纯静态网站环境下,如何利用 Stripe Payment Link 实现商品售卖,并着重讨论了在不暴露 Stripe 密钥的前提下,客户端创建 Payment Link 的可行性。分析了直接在客户端使用密钥的风险,并提出了预先生成 Payment Link 或使用后端服务动态生成 Pay…

    2026年5月10日
    000
  • PHP动态网页数据库备份恢复_PHP动态网页MySQL数据库备份教程

    答案:PHP动态网页的MySQL数据库备份与恢复需通过定期导出SQL文件并安全存储来保障数据安全,核心方法包括使用mysqldump命令行工具实现高效灵活的自动化备份,利用phpMyAdmin图形化工具进行手动导出导入以降低操作门槛,以及通过PHP脚本调用系统命令将备份过程集成到应用中;恢复时可采用…

    2026年5月10日
    000
  • php怎么截取网页_php抓取网页内容的几种方法

    file_get_contents适用于静态页抓取,但受限于allow_url_fopen且无法执行JS;2. cURL支持自定义请求头、Cookie等,适合处理复杂HTTP请求;3. Guzzle作为现代PHP项目推荐方案,具备良好扩展性与异步支持;4. 动态渲染内容需借助Puppeteer或Se…

    2026年5月10日
    000

发表回复

登录后才能评论
关注微信