繁体   English   中英

Faker和Laravel 5

[英]Faker and Laravel 5

我想知道是否有人知道执行此任务的方法。 我想尝试告诉插入的用户每种类型的角色有多少。 这样我就可以说我只想要角色3中角色4和角色2中的另外一个,剩下的就是其中之一。 我确信会有一些额外的逻辑,但不确定应该写这样的东西。

<?php

use Illuminate\Database\Seeder;

// Composer: "fzaninotto/faker": "v1.3.0"
use Faker\Factory as Faker;

use App\User;

class UsersTableSeeder extends Seeder {

    public function run()
    {
        // use the factory to create a Faker\Generator instance
        $faker = Faker::create();

        $roleIds = App\Role::lists('id');

        User::create([
            'first_name' => 'Me',
            'last_name' => 'Me',
            'username' => 'me',
            'email' => 'me@gmail.com',
            'password' => 'secret',
            'active' => 1,
            'role_id' => 1
        ]);

        foreach(range(2, 100) as $index) {

            User::create([
                'first_name' => $faker->firstName,
                'last_name' => $faker->lastName,
                'username' => str_replace('.', '_', $faker->unique()->userName),
                'email' => $faker->email,
                'password' => $faker->word,
                'active' => $faker->boolean($chanceOfGettingTrue = 90),
                'role_id' => $faker->randomElement($roleIds)
            ]);
        }

    }

}

您可以尝试针对特定数量的role_id使用不同的foreach,并根据您的需要修复每个foreach中的id。

<?php

use Illuminate\Database\Seeder;

// Composer: "fzaninotto/faker": "v1.3.0"
use Faker\Factory as Faker;

use App\User;

class UsersTableSeeder extends Seeder {

    public function run()
    {
        // use the factory to create a Faker\Generator instance
        $faker = Faker::create();

        $roleIds = App\Role::lists('id');

        User::create([
            'first_name' => 'Me',
            'last_name' => 'Me',
            'username' => 'me',
            'email' => 'me@gmail.com',
            'password' => 'secret',
            'active' => 1,
            'role_id' => 1
        ]);

        foreach(range(1, 2) as $index) {

            User::create([
                'first_name' => $faker->firstName,
                'last_name' => $faker->lastName,
                'username' => str_replace('.', '_', $faker->unique()->userName),
                'email' => $faker->email,
                'password' => $faker->word,
                'active' => $faker->boolean($chanceOfGettingTrue = 90),
                'role_id' => 1
            ]);
        }

        foreach(range(1, 3) as $index) {

            User::create([
                'first_name' => $faker->firstName,
                'last_name' => $faker->lastName,
                'username' => str_replace('.', '_', $faker->unique()->userName),
                'email' => $faker->email,
                'password' => $faker->word,
                'active' => $faker->boolean($chanceOfGettingTrue = 90),
                'role_id' => 2
            ]);
        }

        foreach(range(2, 100) as $index) {

            User::create([
                'first_name' => $faker->firstName,
                'last_name' => $faker->lastName,
                'username' => str_replace('.', '_', $faker->unique()->userName),
                'email' => $faker->email,
                'password' => $faker->word,
                'active' => $faker->boolean($chanceOfGettingTrue = 90),
                'role_id' => rand(3,5)
            ]);
        }

    }

}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM