laravel数据迁移

简介: laravel数据迁移

数据迁移

迁移就像是数据库的版本控制, 允许团队简单轻松的编辑并共享应用的数据库表结构,迁移通常和 Laravel 的 数据库结构生成器配合使用,让你轻松地构建数据库结构。如果你曾经试过让同事手动在数据库结构中添加字段,那么数据库迁移可以让你不再需要做这样的事情。

生成迁移

php artisan make:migration create_users_table

新的迁移位于database/migrations目录下。每个迁移文件名都包含时间戳,以便让 Laravel 确认迁移的顺序。

--table--create选项可用来指定数据表的名称,或是该迁移被执行时是否将创建的新数据表。这些选项需在预生成迁移文件时填入指定的数据表:

php artisan make:migration create_users_table --create=users
php artisan make:migration add_votes_to_users_table --table=users

运行迁移

php artisan migrate

在生产环境强制执行迁移

一些迁移操作是具有破坏性的, 这意味着可能会导致数据丢失。 为了防止有人在生产环境中运行这些命令, 系统会在这些命令被运行之前与你进行确认。如果要强制忽略系统的提示运行命令, 则可以使用--force标记:

php artisan migrate --force

回滚迁移

若要回滚最后一次迁移, 可以使用rollback命令。 此命令将回滚最后一次“迁移”的操作,其中可能包含多个迁移文件:

php artisan migrate:rollback

你可以在rollback命令后面加上step参数,来限制回滚迁移的个数。 例如,以下命令将回滚最近五次迁移:

php artisan migrate:rollback --step=5

migrate:reset命令可以回滚应用程序中的所有迁移:

php artisan migrate:reset

使用单个命令来执行回滚或迁移

migrate:refresh命令不仅会回滚数据库的所有迁移还会接着运行migrate命令。 这个命令可以高效地重建整个数据库:

php artisan migrate:refresh
// Refresh the database and run all database seeds...
php artisan migrate:refresh --seed

使用refresh命令并提供step参数来回滚并再执行最后指定的迁移数。例如, 以下命令将回滚并重新执行最后五次迁移:

php artisan migrate:refresh --step=5

删除所有表 & 迁移

php artisan migrate:fresh
php artisan migrate:fresh --seed


目录
相关文章
|
10月前
|
关系型数据库 数据库 PostgreSQL
PostgreSQL环境搭建和主备构建 2
PostgreSQL环境搭建和主备构建
286 0
|
1月前
|
存储 监控 数据安全/隐私保护
数据迁移至云:最佳实践与工具
【6月更文挑战第1天】企业在数字化转型中选择将数据迁移至云以获取灵活性、降低成本及增强安全性。迁移前需详细规划,评估目标和需求,选择合适的云服务商。确保数据备份,利用工具如 AWS DataSync 自动化迁移,注意数据格式兼容性,并在迁移中监控、测试数据完整性。保障安全性,设置访问权限和加密。迁移后优化管理云资源,实现最佳性能和成本效益。遵循最佳实践,确保数据迁移顺利。
36 1
|
2月前
|
前端开发 Java OLAP
Doris数据库安装插件流程
【5月更文挑战第1天】Doris数据库安装插件流程
293 2
|
7月前
|
SQL 小程序 PHP
laravel5.8(三)数据库相关操作及配置
数据库相关的操作,大概看下laravel封装的增删改查的数据库操作方法以及laravel对原生sql的支持。 一:执行原生sql 1:查询select php 复制代码 $results = DB::select('select * from users where id = ‘{$id}’'); 2:写入 php 复制代码 $result = DB::insert('insert into users (id, name) values (‘{$id}’, ‘{$name}’)'); 3:修改,该方法返回受更新语句影响的行数:
78 1
|
7月前
|
小程序 关系型数据库 数据库连接
laravel5.8(十一)配置使用多数据库
有的时候,我们在开发的过程中需要连接多个数据库。 Laravel框架中早已为我们想到了这样的需求。 配置很简单。 在根目录下的/config/database.php文件中配置: Laravel中为我们提前预设了多种类型的数据库连接
36 0
|
10月前
|
SQL 关系型数据库 Shell
PostgreSQL环境搭建和主备构建 1
PostgreSQL环境搭建和主备构建
53 0
|
10月前
|
SQL 关系型数据库 数据库
Rails 数据库最佳实践
Rails 数据库最佳实践
|
SQL 关系型数据库 MySQL
「数据架构」数据迁移神器 pgloader,迁移各种数据到PostgreSQL
「数据架构」数据迁移神器 pgloader,迁移各种数据到PostgreSQL
|
数据库
Yii2.0如何进行数据迁移?底层原理是什么?
Yii2.0如何进行数据迁移?底层原理是什么?
145 0