详解Laravel Seeder如何生成百万模拟数据

2022-05-15 0 811

下面由laravel教程栏目给大家介绍Laravel Seeder生成百万模拟数据,希望对需要的朋友有所帮助!

详解Laravel Seeder如何生成百万模拟数据

Laravel 集成了 Faker 库,并提供了 Seeder 可以帮助我们轻松地生成模拟数据。

先书写数据仓库和数据填充代码

数据仓库代码

use App\\Models\\Topic;use Faker\\Generator as Faker;$factory->define(Topic::class, function (Faker $faker) {    $sentence = $faker->sentence();    // 随机取一个月以内的时间    $updated_at = $faker->dateTimeThisMonth();    // 传参为生成最大时间不超过,因为创建时间永远比更改时间要早    $created_at = $faker->dateTimeThisMonth($updated_at);    return [        'title' => $sentence,        'body' => $faker->text(),        'excerpt' => $sentence,        'created_at' => $created_at,        'updated_at' => $updated_at,    ];});

数据填充代码

 class TopicsTableSeeder extends Seeder{    /**     * Run the database seeds.     *     * @return void     */    public function run()    {        // 所有用户ID数组,如:[1,2,3,4]        $user_ids = User::all()->pluck('id')->toArray();        // 所有分类 ID 数组,如:[1,2,3,4]        $category_ids = Category::all()->pluck('id')->toArray();        // 获取 Faker 实例        $faker = app(Faker\\Generator::class);        $topics = factory(Topic::class)            ->times(1000)            ->make()            ->each(function ($topic, $index) use ($user_ids, $category_ids, $faker){                // 从用户 ID 数组中随机取出一个并赋值                $topic->user_id = $faker->randomElement($user_ids);                // 话题分类,同上                $topic->category_id = $faker->randomElement($category_ids);            });        // 将数据集合转换为数组,并插入到数据库中        Topic::insert($topics->toArray());    }}

我们通过是 times() 设置了填充的次数,执行数据填充命令,可以将 1000 条数据填充至 topics 表中,这很方便。

php artisan db:seed --class=TopicsTableSeeder

如果我们想要插入 100w 条数据,是不是把 times() 的参数改为 1000,000 就可以了?当你这样做之后,你会发现如下报错

General error: 1390 Prepared statement contains too many placeholders

这个问题是因为 mysql 默认支持的占位符最多为 65535(2^16-1) 个,写入数据为 m 列,n 行。m*n 必须小于 65535。

所以没法一次性插入大量数据,查了一下 php artisan db:seed 也没有提供执行次数的相关参数。

最后,决定使用 shell 脚本进行解决。

for (( i = 0; i < 1000; i++ )); do    /usr/local/bin/php artisan db:seed --class=TopicsTableSeederdone

等待片刻,你会发现 100w 数据已经生成完毕!

PS:数据仓库和数据填充代码来自 larabbs

推荐:最新的五个Laravel视频教程

收藏 (0) 打赏

感谢您的支持,我会继续努力的!

打开微信/支付宝扫一扫,即可进行扫码打赏哦,分享从这里开始,精彩与您同在
点赞 (0)

【声明:根据2013年1月30日《计算机软件保护条例》2次修订第17条规定: 为了学习和研究软件内含的设计思想和原理,通过安装、显示、传输或者存 储软件等方式使用软件的,可以不经软件著作权人许可,不向其支付报酬! 鉴于此,也希望大家按此说明研究软件!】
本站所有源码尽量保证原汁原味,如有特殊情况会作出声明及标注,网站资源不做任何二次加密(原版加密除外,不影响程序使用的不会做解密处理),方便您更好的学习参考。 在您的能力范围内,为了大环境的良性发展,请尽可能的选择正版资源。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。

即刻码站__国内靠谱的站长资源下载平台 php教程 详解Laravel Seeder如何生成百万模拟数据 https://www.jike1995.com/37133.html

常见问题
  • 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用
查看详情
  • 最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度
查看详情

相关文章

发表评论
暂无评论
官方客服团队

为您解决烦忧 - 24小时在线 专业服务