php - La transformation un-à-plusieurs de Laravel Eloquent n'a aucun problème de valeur
过去多啦不再A梦
过去多啦不再A梦 2017-05-27 17:43:22
0
1
705

Maintenant, il y a Topic, Post, Comment三个模型, Comment相对Topic和Post是一对多的关系, 也就是说每个Topic和Post都可以有多条Comment.
但现在尝试插入Comment时, 发现并没有插入对应的commentable_idcommentable_type???
L'erreur est signalée comme suit :

SQLSTATE[HY000]: General error: 1364 Field 'commentable_id' doesn't have a default value (SQL: insert into `comments` (`content`, `updated_at`, `created_at`)

AppModelsComment

public function commentable()
{
    return $this->morphTo();
}

AppModelsTopic

public function comments()
{
    return $this->morphMany('App\Models\Comment', 'commentable');
}

AppModelsPost

public function comments()
{
    return $this->morphMany('App\Models\Comment', 'commentable');
}

Le tableau de données des commentaires contient $table->morphs('commentable');.

Excusez-moi, quel est le problème ?`

过去多啦不再A梦
过去多啦不再A梦

répondre à tous(1)
迷茫

incomments 表中需要建立 commentable_idcommentable_type字段.如下图所示,其中, commentable_id 用于存放Topic或者Post的 id ,而 commentable_type est utilisé pour stocker le nom de classe du modèle auquel il appartient.

Vous pouvez examiner de plus près l'association polymorphe dans la documentation de Laravel.

Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal