>  기사  >  PHP 프레임워크  >  Laravel Seeder가 수백만 개의 시뮬레이션 데이터를 생성하는 방법에 대한 자세한 설명

Laravel Seeder가 수백만 개의 시뮬레이션 데이터를 생성하는 방법에 대한 자세한 설명

藏色散人
藏色散人앞으로
2021-03-26 17:01:102748검색

튜토리얼 칼럼에서 Laravel Seeder에 대한 백만 개의 시뮬레이션 데이터를 소개하는 내용입니다. 필요한 친구들에게 도움이 되길 바랍니다!

Laravel은 Faker 라이브러리를 통합하고 시뮬레이션 데이터를 쉽게 생성할 수 있도록 Seeder를 제공합니다.

Laravel 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개의 데이터를 채웁니다. topic 테이블은 매우 편리합니다.

php artisan db:seed --class=TopicsTableSeeder

100만 개의 데이터를 삽입하려면 times()의 매개변수를 1000,000으로 변경하면 되나요? 이렇게 하면 다음과 같은 오류가 발생합니다.

General error: 1390 Prepared statement contains too many placeholders

이 문제는 mysql이 기본적으로 최대 65535(2^16-1)개의 자리 표시자를 지원하고, 작성된 데이터가 m열과 n행이기 때문에 발생합니다. m*n은 65535보다 작아야 합니다.

그래서 한번에 많은 양의 데이터를 삽입하는 것은 불가능합니다.

확인해 보면 실행 횟수에 해당하는 매개 변수가 없습니다.

결국 이를 해결하기 위해 쉘 스크립트를 사용하기로 결정했습니다.

for (( i = 0; i < 1000; i++ )); do
    /usr/local/bin/php artisan db:seed --class=TopicsTableSeederdone
php artisan db:seed잠시만 기다리시면 100만개의 데이터가 생성된 것을 보실 수 있습니다!

PS: 데이터 웨어하우스 및 데이터 채우기 코드는 larabbs

권장:

최신 5개 Laravel 비디오 튜토리얼

위 내용은 Laravel Seeder가 수백만 개의 시뮬레이션 데이터를 생성하는 방법에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 learnku.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제