0

0

Laravel如何执行数据库迁移Migration_Laravel数据表创建与字段修改命令【说明】

冰火之心

冰火之心

发布时间:2026-01-07 16:04:02

|

122人浏览过

|

来源于php中文网

原创

Laravel迁移必须通过php artisan make:migration生成文件并执行php artisan migrate,禁止跳过校验或手动操作数据库,否则破坏migrations表一致性,导致回滚失败与协作事故。

laravel如何执行数据库迁移migration_laravel数据表创建与字段修改命令【说明】

直接执行迁移命令就能创建表或修改结构,但必须先写好迁移文件,且不能跳过 php artisan migrate 的校验逻辑。

如何生成并运行新建数据表的迁移文件

新建表必须通过 php artisan make:migration 生成文件,再在 up() 方法里用 Schema::create() 定义字段。Laravel 不允许直接执行 SQL 创建表——它依赖迁移文件记录版本和回滚能力。

  • 运行 php artisan make:migration create_users_table 生成空迁移文件
  • 编辑该文件,在 up() 中调用 Schema::create('users', function (Blueprint $table) { ... })
  • 字段定义用 $table->id()$table->string('name') 等方法,不是原生 SQL
  • 确认无误后执行 php artisan migrate,Laravel 自动记录到 migrations

如何安全地修改已有数据表字段(比如加字段、改类型)

不能直接用 ALTER TABLE 手动操作,否则 migrations 表会丢失记录,后续部署或回滚会出错。所有变更都得走新迁移文件 + Schema::table()

  • 运行 php artisan make:migration add_email_to_users_table(命名需体现意图)
  • up() 中写 Schema::table('users', function (Blueprint $table) { $table->string('email')->after('name'); });
  • 如果要改字段类型(如 stringtext),需确保数据库驱动支持 change(),MySQL 需装 doctrine/dbal 扩展
  • 执行 php artisan migrate,Laravel 检查 migrations 表后只运行未记录的迁移

常见报错:‘SQLSTATE[HY000]: General error: 1824 Failed to open the referenced table’

这通常发生在迁移中定义了外键,但被引用的表还没创建,或迁移执行顺序错乱。Laravel 按文件名前缀(时间戳)排序执行,不是按文件创建顺序。

360智图
360智图

AI驱动的图片版权查询平台

下载
  • 检查迁移文件名是否为标准格式:2023_05_12_100000_create_posts_table.php
  • 外键关联的表迁移必须在当前迁移之前执行,比如 posts 表引用 users,则 create_users_table 的时间戳必须更早
  • 不要手动修改迁移文件名中的时间戳来“抢序”,会导致本地与生产环境不一致
  • 若已出错,先用 php artisan migrate:rollback --step=1 回退一步,再修复依赖关系重新迁移

为什么不能跳过迁移直接操作数据库?

因为 migrations 表是 Laravel 迁移系统唯一的状态源。删掉某条记录、手动建表、或用其他工具改结构,都会让 php artisan migrate:status 显示异常,rollback 失效,团队协作时极易引发线上事故。

  • php artisan migrate:status 查看哪些迁移已执行、哪些待运行
  • php artisan migrate:fresh 仅用于本地开发重置,它会 DROP 所有表,线上绝对禁用
  • 生产环境修改字段,必须走新增迁移文件,哪怕只是加个 nullable()
php artisan make:migration add_status_to_posts_table
// 编辑该文件:
public function up(MigrationBuilder $migration)
{
    Schema::table('posts', function (Blueprint $table) {
        $table->string('status')->default('draft')->after('title');
    });
}
// 再运行:
php artisan migrate

真正麻烦的从来不是命令怎么敲,而是迁移文件写完之后,有没有人记得把它提交进 Git、有没有人在上线前漏跑那一条 migrate、以及——有没有人偷偷绕过它直接连上数据库改了字段。

相关专题

更多
php文件怎么打开
php文件怎么打开

打开php文件步骤:1、选择文本编辑器;2、在选择的文本编辑器中,创建一个新的文件,并将其保存为.php文件;3、在创建的PHP文件中,编写PHP代码;4、要在本地计算机上运行PHP文件,需要设置一个服务器环境;5、安装服务器环境后,需要将PHP文件放入服务器目录中;6、一旦将PHP文件放入服务器目录中,就可以通过浏览器来运行它。

2285

2023.09.01

php怎么取出数组的前几个元素
php怎么取出数组的前几个元素

取出php数组的前几个元素的方法有使用array_slice()函数、使用array_splice()函数、使用循环遍历、使用array_slice()函数和array_values()函数等。本专题为大家提供php数组相关的文章、下载、课程内容,供大家免费下载体验。

1501

2023.10.11

php反序列化失败怎么办
php反序列化失败怎么办

php反序列化失败的解决办法检查序列化数据。检查类定义、检查错误日志、更新PHP版本和应用安全措施等。本专题为大家提供php反序列化相关的文章、下载、课程内容,供大家免费下载体验。

1400

2023.10.11

php怎么连接mssql数据库
php怎么连接mssql数据库

连接方法:1、通过mssql_系列函数;2、通过sqlsrv_系列函数;3、通过odbc方式连接;4、通过PDO方式;5、通过COM方式连接。想了解php怎么连接mssql数据库的详细内容,可以访问下面的文章。

951

2023.10.23

php连接mssql数据库的方法
php连接mssql数据库的方法

php连接mssql数据库的方法有使用PHP的MSSQL扩展、使用PDO等。想了解更多php连接mssql数据库相关内容,可以阅读本专题下面的文章。

1413

2023.10.23

html怎么上传
html怎么上传

html通过使用HTML表单、JavaScript和PHP上传。更多关于html的问题详细请看本专题下面的文章。php中文网欢迎大家前来学习。

1233

2023.11.03

PHP出现乱码怎么解决
PHP出现乱码怎么解决

PHP出现乱码可以通过修改PHP文件头部的字符编码设置、检查PHP文件的编码格式、检查数据库连接设置和检查HTML页面的字符编码设置来解决。更多关于php乱码的问题详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1444

2023.11.09

php文件怎么在手机上打开
php文件怎么在手机上打开

php文件在手机上打开需要在手机上搭建一个能够运行php的服务器环境,并将php文件上传到服务器上。再在手机上的浏览器中输入服务器的IP地址或域名,加上php文件的路径,即可打开php文件并查看其内容。更多关于php相关问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

1304

2023.11.13

java学习网站推荐汇总
java学习网站推荐汇总

本专题整合了java学习网站相关内容,阅读专题下面的文章了解更多详细内容。

6

2026.01.08

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 1.7万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 785人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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