Laravel的数据迁移功能很好用,并且可以带来一系列好处。
通过几条简单的 artisan 命令,就可以顺利上手,没有复杂的地方

注意:该系列命令对数据库非常危险,请准备一个单独的数据库作为配套练习,假设你已经新建了一个空的数据库

首先新建一个迁移表文件,比如test表

php artisan make:migration CreateTestTable (文件名格式并没有要求)

这个时候项目中生成了一个新的迁移文件,在 project/database/migrations/ 目录下

打开这个文件,编辑表结构

public function up()
{
Schema::create('test', function (Blueprint $table) {
$table->increments('id');
$table->string('name',30);
$table->integer('sex');
$table->timestamps();
});
}

这个时候数据库应该还是空的,没有任何表,这个时候执行:

php artisan migrate:fresh

现在数据库里面多了一张test表了,然后在打开迁移文件,增加字段或者删除字段等修改,再次执行上面的命令,数据库的test表被刷新了。

到此Laravel的数据库迁移就已经完了。

但是通常还有一个功能和数据库迁移经常同事存在,为了方便调试我们通常要往数据库里面填充一些数据,就是数据填充。

php artisan make:seed TestSeeder

这个时候项目中生成了一个新的seeder文件,在 project/database/seeds/ 目录下

打开并编辑里面的run方法:

public function run()
{
\Illuminate\Support\Facades\DB::table('test')
->insert([
'name' => '张三' . str_random(),
'sex' => rand(0,1)
]);
}

打开seeds目录下自带的  DatabaseSeeder.php 文件,编辑run方法

public function run()
{
$this->call(TestSeeder::class);
}

然后执行  php artisan db:seed

这个时候 test 表会增加一条数据,如果要一次批量增加更过数据可以这样:

public function run()
{
for ($i = 0; $i < 100; $i++) {
$this->call(TestSeeder::class);
}
}

这种数据填充的方式不是很优雅,我们换一种更好的方式来实现数据填充

新建一个 Test 模型: php artisan make:model Test

这个时候项目中生成了一个新的Model文件,在 project/app/ 目录下

打开文件添加一个属性  protected $table = 'test'; (绑定表)

在创建一个模型工厂: php artisan make:factory TestFactory

这个时候项目中生成了一个新的Factory文件,在 project/database/factories/ 目录下,打开并编辑:

$factory->define(\App\Test::class, function (Faker $faker) {
return [
'name' => $faker->name,
'sex' => $faker->biasedNumberBetween(0,1)
];
});

重新打开并编辑对应的Seeder文件:TestSeeder.php

public function run()
{
factory(\App\Test::class,50)->create();
// \Illuminate\Support\Facades\DB::table('test')
// ->insert([
// 'name' => '张三' . str_random(),
// 'sex' => rand(0,1)
// ]);
}

再次执行: php artisan db:seed ,这个时候数据库一次多了50条数据

常用命令组合

php artisan migrate:fresh --seed (重建数据表结构并执行数据填充)

其他

对于老项目想要快速介入 Laravel的数据迁移,一个表一个表的去建 Migrate显然是很累的,github上有一个将根据表自动生成migrate的库可供参考:

https://github.com/Xethron/migrations-generator

注意: 最近发现这个库还有有一些问题,生成迁移文件后还是挨个检查一下,在本地运行看看结果

Laravel数据库迁移的更多相关文章

  1. laravel数据库迁移(三)

    laravel号称世界上最好的框架,数据库迁移算上一个,在这里先简单入个门: laravel很强大,它把表中的操作写成了migrations迁移文件,然后可以直接通过迁移文件来操作表.所以 , 数据迁 ...

  2. laravel数据库——迁移

    1.简介 迁移就像数据库的版本控制,允许团队简单轻松的编辑并共享应用的数据库表结构,迁移通常和Laravel的结构构建器结对从而可以很容易地构建应用的数据库表结构. Laravel的Schema门面提 ...

  3. laravel 数据库迁移转 sql 语句

    可以使用下面的命令 php artisan migrate --pretend --no-ansi 当然,你需要有可以 migrate 的东西. 数据库迁移导出到文件(使用命令) <?php n ...

  4. laravel 数据库迁移

    问题:之前有创建迁移文件 并且执行过 如果删除迁移文件 再重新创建迁移文件时就有问题 提示找不到之前的迁移文件 /** 一开始执行的命令 php artisan make:migration crea ...

  5. laravel数据库迁移的migrate小解

    当通过命令行:php artisan migrate:make create_authors_table --table=authors --create时,在 migration.php 中若Sch ...

  6. laravel数据库迁移 和 路由防攻击

    命令:php  artisan  migrate 防攻击:

  7. 转: Laravel的数据库迁移 介绍的比较清晰

    原文: https://blog.sbot.io/articles/12/Laravel-数据库迁移(Database-Migrations)操作实例 很多人可能在学习Laravel框架的时候,对La ...

  8. Laravel学习笔记(四)数据库 数据库迁移案例

    创建迁移 首先,让我们创建一个MySql数据库“Laravel_db”.接下来打开app/config目录下的database.php文件.请确保default键值是mysql: return arr ...

  9. Laravel学习笔记(三)数据库 数据库迁移

    该章节内容翻译自<Database Migration using Laravel>,一切版权为原作者. 原作者:Stable Host, LLC 翻译作者:Bowen Huang 正文: ...

随机推荐

  1. 多机同步管理hexo博客

    转载自:https://www.zhihu.com/question/21193762/answer/79109280 一.关于搭建的流程 创建仓库,<your github username& ...

  2. 为什么使用 Redis 及其产品定位

    一:传统 MySQL+ Memcached 架构遇到的问题 实际 MySQL 是适合进行海量数据存储的,通过 Memcached 将热点数据加载到 cache,加速访问,很多公司都曾经使用过这样的架构 ...

  3. java class反编译工具----JD-GUI

    下载地址   http://jd.benow.ca/

  4. Powershell-获取MAC地址对应IP信息

    因业务需要在DHCP服务器上绑定设备MAC,提示"指定的IP地址或硬件地址正被其他客户端使用",与业务同事沟通之前该设备做过地址保留,具体对应地址遗忘了. 问题描述: a.按照用户 ...

  5. MacBook Pro 安装win7 64 成功安装过程总结

    安装对象: MacBook Pro (13 英寸, 2010 年中) 中安装win7 64位操作系统(原版安装非Ghost),且只保留win7系统即可. 场景还原: 拿到笔记本时,笔记本中已无Mac ...

  6. 使用bootstrap的dropdown部件时报错:error:Bootstrap dropdown require Popper.js

    前言:前端小白一枚,刚注册博客,先发个学习过程中新碰到小问题试试水吧~ 摘要:最近在学习bootstrap,偶然碰到了一个小问题,bootstrap网站也没有做过多的解释,今天分享给大家. 问题描述: ...

  7. Ubuntu 18.04中截图工具Shutter的编辑按钮不可用的解决办法

    Shutter是一个由第三方提供的在Ubuntu上运行的截图工具,相对于系统自带的截图工具(默认可通过Ctrl + Shift + Print快捷键启动截图),最大的优点就是可以即时对图片进行编辑,在 ...

  8. 做嵌入式,C语言相关的朋友不要错过

    前言 相对来讲嵌入式相关的人群总体来说比较少,那么有没有一个聚集地呢? 为回馈读者,「编程珠玑」与「嵌入式linux」,「EmbeddDeveloper」三个公众号联合组织了此次福利活动,「编程珠玑」 ...

  9. CENTOS重新安装JDK

    centos 删除默认安装的JDK 重新安装JDK 1.删除JDK 通过xshell工具成功连接安装好的虚拟机之后可通过    rpm -qa | grep java  或 rpm -qa | gre ...

  10. 小程序--scroll-view的横向滑动无效