数据库 – Laravel 4:处理种子关系

前端之家收集整理的这篇文章主要介绍了数据库 – Laravel 4:处理种子关系前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
在L4的新种子功能中是否有一种简单的方式来管理多对多关系?

一种方法是为数据透视表制作种子,但我会做很多工作.

对这种事情有一个好的工作流程的任何想法?

解决方法

在最新版本的Laravel 4中,您可以定义所有播种器脚本在 DatabaseSeeder类的“run”方法中运行的顺序.
public function run()
{
    DB::statement('SET FOREIGN_KEY_CHECKS=0;');

    $this->call('PrimaryTableOneSeeder');
    $this->command->info('The first primary table has been seeded!');

    $this->call('PrimaryTableTwoSeeder');
    $this->command->info('The second primary table has been seeded!');

    $this->call('PivotTableSeeder');
    $this->command->info('The pivot table has been seeded!');

    DB::statement('SET FOREIGN_KEY_CHECKS=1;');
}

你会发现我在运行所有播种之前和之后禁用外键约束.这可能是不好的做法,但这是我可以使用truncate函数重新设置每个表的id计数的唯一方法.如果您遵循inserting related models的指南,这种做法可能是不必要的.

class PrimaryTableOneSeeder extends Seeder {

public function run()
{
    DB::table('primaryone')->truncate();
    Primaryone::create(array(
        'field' => 'value','created_at' => new DateTime,'updated_at' => new DateTime
    ));
}

要在我的示例中使用mass assignment,并且作为最新版本的文档,您需要为模型指定一些保护的或可填充的列.为此,只需将属性添加到您的模型中,如下所示:

class Primaryone extends Eloquent {

protected $guarded = array('id');

猜你在找的MsSQL相关文章