目標是用強制性和隨機選單項填充表格。
以下案例僅適用于隨機專案
父表
$parents = [
['id' => 1, 'parent' => 'AA'],
['id' => 2, 'parent' => 'BB'],
['id' => 3, 'parent' => 'CC'],
];
填充選單表
$menus = [
['id' => 1, 'menu' => 'A'],
['id' => 2, 'menu' => 'B'],
['id' => 3, 'menu' => 'C'],
['id' => 4, 'menu' => 'D'],
['id' => 5, 'menu' => 'E'],
];
foreach ($menus as $menu) {
modelMenu::updateOrCreate([ 'id' => $menu['id']], $menu);
}
關系
$menus = Menu::all();
Parent::all()->each(function ($parent) use ($menus) {
$parent->menus()->attach(
$menus->random(rand(1, 5))->pluck('id')->toArray()
);
});
楷模
class Parent extends Model
{
protected $fillable = ['parents'];
public function menus()
{
return $this->hasMany(Menu::class);
}
}
class Menu extends Model
{
protected $fillable = ['menus'];
public function parents()
{
return $this->belongsTo(Parent::class);
}
}
我打算實作的是每個父母都必須有相關的 ids 1 和 2 選單;
選單 3、4 和 5 隨機添加。
例子:
Parent AA - menus with ids 1, 2, 5;
Parent BB - menus with ids 1, 2, 4, 6;
Parent CC - menus with ids 1, 2, 3;
uj5u.com熱心網友回復:
這應該可以達到您想要的結果:
$menus = Menu::all()->values();
Parent::all()->each(function ($parent) use ($menus) {
$parent->menus()->attach([
$menus->get(0)->id,
$menus->get(1)->id,
...$menus->whereNotIn('id', [1,2])->random(rand(1, 5))->pluck('id')
]);
});
values()方法回傳一個帶有鍵的新集合,您可以利用get(index)其余的基本上獲取的隨機記錄來獲取第一條和第二條記錄,并whereNotIn('id', [1,2])跳過具有 ids [1, 2] 的記錄。
轉載請註明出處,本文鏈接:https://www.uj5u.com/yidong/422703.html
標籤:
