2017-07-04 56 views
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 {

你如何建议我继续?

回答

0

它不是很清楚如何使你的关系设置,但是从我的理解需要被添加到订阅用户,所以这可能做到这一点:

public function run() 
{ 
    factory(App\Fund::class, 15)->create()->each(function ($u) { 
     $u->subscriptions()->save(factory(App\Subscription::class)->make()); 
     $subscription = App\Subscription::latest()->get()->last(); 
     $subscription->subscribers()->save(factory(App\Subscriber::class)->make()); 
    }); 
} 
+0

我在原来的问题加我的模型 - 请参阅帖子的顶部以作进一步澄清。尽管我确实感觉自己在尝试使用某些方法,但尝试使用方法会导致以下错误[BadMethodCallException]调用未定义的方法Illuminate \ Database \ Query \ Builder :: save() – chillyner