The following tutorial column will introduce you to Laravel Seeder to generate millions of simulated data. I hope it will be helpful to friends in need!
Laravel integrates the Faker library and provides Seeder to help us easily generate simulation data.First write the data warehouse and data filling code
Data warehouse code
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, ];});
Data filling code
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()); }}
We set the filling through times() Number of times, execute the data filling command to fill 1000 pieces of data into the topics table, which is very convenient.
php artisan db:seed --class=TopicsTableSeeder
If we want to insert 1 million pieces of data, can we just change the parameters of times() to 1000,000? When you do this, you will find the following error
General error: 1390 Prepared statement contains too many placeholders
This problem is because mysql supports a maximum of 65535 (2^16-1) placeholders by default, and the written data is m columns and n rows . m*n must be less than 65535.
So it is impossible to insert a large amount of data at one time. After checking
php artisan db:seed, there is no relevant parameter for the number of executions.
Finally, I decided to use a shell script to solve it. <div class="code" style="position:relative; padding:0px; margin:0px;"><pre class="brush:php;toolbar:false">for (( i = 0; i < 1000; i++ )); do
/usr/local/bin/php artisan db:seed --class=TopicsTableSeederdone</pre><div class="contentsignin">Copy after login</div></div>
Wait for a moment, you will find that 1 million data has been generated!
PS: The data warehouse and data filling code comes from larabbs
Recommended:The latest five Laravel video tutorials
The above is the detailed content of Detailed explanation of how Laravel Seeder generates millions of simulation data. For more information, please follow other related articles on the PHP Chinese website!