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

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

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

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

解决方法

在最新版本的Laravel 4中,您可以定义所有播种器脚本在 DatabaseSeeder类的“run”方法中运行的顺序. @H_404_10@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的指南,这种做法可能是不必要的.

@H_404_10@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,并且作为最新版本的文档,您需要为模型指定一些保护的或可填充的列.为此,只需将属性添加到您的模型中,如下所示:

@H_404_10@class Primaryone extends Eloquent { protected $guarded = array('id');

猜你在找的MsSQL相关文章