0
我试图建立一个模型厂Laravel 5.4以下关系:多层次模型厂的关系在Laravel 5.4
基金
-----认购
------- ----订户
每个基金都有很多订阅,而且每个订阅者也有很多订阅。订阅属于基金,也属于订阅者。
我想在Laravel(雄辩)中建立一个模型工厂来完成单个播种机中的这种关系。以下是我迄今为止:
应用程序\基金
public function subscriptions()
{
return $this->hasMany('App\Subscription');
}
public function subscribers()
{
return $this->hasMany('App\Subscriber');
}
应用程序\认购
public function subscriber()
{
return $this->belongsTo('App\Subscriber');
}
public function fund()
{
return $this->belongsTo('App\Fund');
}
应用程序\用户
public function subscriptions()
{
return $this->hasMany('App\Subscription');
}
厂为\软件\基金
$factory->define(App\Fund::class, function (Faker\Generator $faker) {
return [
'code' => strtoupper($faker->lexify('?????')).$faker->numberBetween('10000', '99999'),
'name' => $faker->text('45'),
'status' => 'Active',
'currency' => $faker->currencyCode(),
'location' => $faker->country(),
'redeemable' => $faker->boolean(50),
'interest_rate' => $faker->randomFloat(2, 0, 0.99),
'interest_frequency' => 'Quarterly',
'management_fee' => $faker->randomFloat(2, 0, 0.99),
'inclusion_rate' => $faker->randomFloat(2, 0, 0.99),
'notes' => $faker->sentences(6, TRUE),
];
});
厂为\软件\认购
$factory->define(App\Subscription::class, function (Faker\Generator $faker) {
return [
'code' => $faker->numberBetween('10000', '99999'),
'amount' => $faker->randomFloat(2, 2000, 18000),
'purchase_price' => $faker->randomFloat(2, 5, 25),
'qty_purchased' => $faker->randomFloat(4, 1000, 20000),
'date' => date("Y-m-d H:i:s"),
];
});
厂为\软件\用户
$factory->define(App\Subscriber::class, function (Faker\Generator $faker) {
return [
'name' => $faker->name,
'email' => $faker->freeEmail,
'phone' => $faker->phoneNumber,
'fax' => $faker->phoneNumber,
'address' => $faker->address,
];
});
FundSeeder.php
public function run()
{
factory(App\Fund::class, 15)->create()->each(function ($u) {
$u->subscriptions()->save(factory(App\Subscription::class)->make());
$u->subscribers()->save(factory(App\Subscriber::class)->make());
});
}
然而,当我运行php artisan db:seed
,返回以下错误:
http://i.imgur.com/FFt6gFt.png
这是正确的,但是,因为我不想对认购表fund_id
值。基金有很多订阅,而订阅者有很多订阅。
真正的问题是,我无法弄清楚如何一次创建所有三个模型而不会导致错误。
这将是有意义的,对我来说,要做到这一点:
public function run()
{
factory(App\Fund::class, 2)->create()->each(function ($u) {
$u->subscriptions()->save(factory(App\Subscription::class)->make({
$u->subscribers()->save(factory(App\Subscriber::class)->make());
}));
});
}
然而,这导致Syntax Error - Unexpected {
。
你如何建议我继续?
我在原来的问题加我的模型 - 请参阅帖子的顶部以作进一步澄清。尽管我确实感觉自己在尝试使用某些方法,但尝试使用方法会导致以下错误[BadMethodCallException]调用未定义的方法Illuminate \ Database \ Query \ Builder :: save() – chillyner