- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
tl;dr:
我正在使用 Laravel 和 Eloquent 并尝试为数据库播种并将多个属于关系附加到一个表,但我收到错误:
Call to undefined method Illuminate\Database\Eloquent\Relations\BelongsTo::attach()
详细解释:
我在 Eloquent 中使用 php 7.1
和 Laravel 6
。我正在尝试为测试数据库播种。我有以下关系结构:
一个用户有多个帖子/一个帖子属于一个用户
一个类别有多个帖子/一个帖子属于一个类别
用户模型:
class User extends Model
{
protected $table = 'users';
public function posts()
{
return $this->hasMany('App\Models\Post');
}
}
类别模型:
class Category extends Model
{
protected $table = 'categories';
public function posts()
{
return $this->hasMany('App\Models\Category');
}
}
后模型:
class Post extends Model
{
protected $table = 'posts';
public function category()
{
return $this->belongsTo('App\Models\Category');
}
public function user()
{
return $this->belongsTo('App\Models\User');
}
}
用户工厂:
$factory->define(User::class, function (Faker $faker) {
return [
'id' => $faker->unique()->randomNumber(3),
'name' => $faker->name(),
];
});
类别工厂:
$factory->define(Category::class, function (Faker $faker) {
return [
'id' => $faker->unique()->randomNumber(3),
'name' => $faker->word(),
];
});
邮局:
$factory->define(User::class, function (Faker $faker) {
return [
'id' => $faker->unique()->randomNumber(3),
'name' => $faker->realText($maxNbChars = 200, $indexSize = 2),
];
});
如果我只有用户和帖子,我知道我可以通过以下方式为数据库播种:
public function seed()
{
$users = factory(App\User::class, 10)
->create()
->each(function ($user) {
$user->posts()->createMany(factory(App\Post::class, 10)->make()->toArray());
});
}
但显然这对我来说行不通。我尝试了以下方法:
public function seed()
{
factory(User::class, 10)->create();
factory(Category::class, 10)->create();
factory(Post::class, 100)->create()->each(function ($post){
$post->user()->attach(User::all()->random(1));
$post->category()->attach(Category::all()->random(1));
});
}
以及使用 make/save 而不是 create 的相同功能:
public function seed()
{
factory(User::class, 10)->create();
factory(Category::class, 10)->create();
factory(Post::class, 100)->make()->each(function ($post) {
$post->user()->attach(User::all()->random(1));
$post->category()->attach(Category::all()->random(1));
})->save();
}
但在这两种情况下,我都得到了错误:
Call to undefined method Illuminate\Database\Eloquent\Relations\BelongsTo::attach()
最佳答案
你必须使用associate()
:
public function seed()
{
factory(User::class, 10)->create();
factory(Category::class, 10)->create();
factory(Post::class, 100)->make()->each(function ($post) {
$post->user()->associate(User::inRandomOrder()->first());
$post->category()->associate(Category::inRandomOrder()->first());
$post->save();
});
}
此外 User::all()->random(1)
将返回一个集合而不是模型,这将引发异常,我将其替换为 Model::inRandomOrder( )->first()
,它将从数据库中获取一个随机模型。
来自docs :
When updating a belongsTo relationship, you may use the associate method. This method will set the foreign key on the child model:
$account = App\Account::find(10);
$user->account()->associate($account);
$user->save();
更新
在您的模型工厂中:
/** @var Factory $factory */
$factory->define(Post::class, function (Faker\Generator $faker) {
return [
// not sure why you do this, is it not a autoincrement column?
'id' => $faker->unique()->randomNumber(3),
'name' => $faker->realText($maxNbChars = 200, $indexSize = 2),
'category_id' => function () {
if ($category = Category::inRandomOrder()->first()) {
return $category->id;
}
return factory(Category::class)->create()->id;
},
'user_id' => function () {
if ($user = User::inRandomOrder()->first()) {
return $user->id;
}
return factory(User::class)->create()->id;
},
];
});
在你的播种机中:
public function seed()
{
factory(User::class, 10)->create();
factory(Category::class, 10)->create();
factory(Post::class, 100)->create();
}
关于php - Laravel:有几个种子表属于使用工厂的关系,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62148552/
如果有一张有客户的 table 和一张有地址的 table 。 一位客户必须(仅)有一个地址,但地址不必有客户(取决于字段类型)。所以我只是问如何告诉cake在寻找客户时获取客户地址,但在寻找地址时不
我有一个问题,我需要获取我的画廊表的所有图像(路径),该表拥有博物馆和拥有博物馆的用户。我得到了图像的路径,但这些与拥有博物馆的 user_id 没有关联。 所以简短的描述: 每个用户拥有一个博物馆,
我有一个问题,我需要获取我的画廊表的所有图像(路径),该表拥有博物馆和拥有博物馆的用户。我得到了图像的路径,但这些与拥有博物馆的 user_id 没有关联。 所以简短的描述: 每个用户拥有一个博物馆,
我有用户和个人资料(一对一属于用户) type User struct { ID int Username string Password string
我想以类似于'belongs to' association的方式使用GORM的Django's one-to-one relationships。考虑以下示例,其中每个User与一个Profile相
长期从事 Rails 开发, Backbone 菜鸟。 在我的 Rails 模型中,一个项目有很多任务,一个任务属于一个项目......标准的东西。 尝试在集合中获取项目的任务 json。 Examp
让我们直奔问题(使用 Grails 1.1.1,它应该适用于以前的问题) 我有 2 个域,即:用户和详细信息,如下所示: Class User { String userName ; ..
我正在尝试在 Rails 中设置模型关系,并且需要您的帮助,因为它不起作用:0 class User :creator_id end 就架构而言,request_threads表具有creator_
注意:我在编写问题时解决了问题,因此不需要答案。仍然与答案分享,以便有相同经历的人可以从中受益。 我有一个回收器 View ,其中包含图像和 2 个 TextView 。我想在单击图像时旋转图像,但发
我正在尝试为我的应用程序中的所有按钮添加自定义点击声音。我已经为 UIButton 创建了一个类类别,其中包含以下代码: NSURL *soundURL = [NSURL fileURLWithPat
我有这样一个IP:12.12.12.12 我正在遍历不同的 IP 范围(12.12.12.0/24(示例))格式,并尝试查看 IP 是否在该范围内。 我尝试了各种方法,例如 inet_addr 和比较
看完这个问题 ASP.NET MVC: Nesting ViewModels within each other, antipattern or no? 和 Derick Bailey 的评论 i t
我正在使用 FeedWordPress 从子公司网页将新闻导入母公司的新闻卷。 可在此处查看特定项目的 RSS 摘录:Pastebin 如您所见,我正在将我需要的图像放入 RSS 文件、描述 bloc
假设我有以下数据库架构: dogs 和 owners 与经典的 belongsToMany 相关联。 walks 表怎么样?我希望能够在这种关系中使用 Eloquent 好东西: $dogs = Do
我不知道出了什么问题,但我无法使用 :class_name 选项让belongs_to 工作。有人可以启发我。非常感谢! 这是我的代码片段。 class CreateUsers false
属于 JavaScript 对象原型(prototype)的回调函数如何访问对象成员?回调不能关闭,一切都必须定义如下: function Obji(param){ this.element =
有人可以解释一下 MarkupCompilePass1 和 PartialClassGenerationTask 这两个构建任务是如何归属在一起的吗?目前我不知道他们是否共存或者是否需要对方。有人可以
现在,我尝试了解 Grails 域类和 GORM 中的工作原理。所以,我尝试实验: 我试验了两个域类:Main 和 Sub。 我们走吧! 第 1 步: class Main { String
所以我有一个模型 App.DailyEntry = DS.Model.extend({ user_id: belongsTo('user'), entries: hasMany('En
我正在使用 primeng 组件选项卡菜单。 https://www.primefaces.org/primeng/#/tabmenu我找不到将所选 TAB 的颜色更改为不同颜色的方法。 最佳答案 抱
我是一名优秀的程序员,十分优秀!