雄辩的同步和created_at/updated_at

2022-08-30 13:18:44

我有以下代码:

$entry->save();

$categories = [];

$categories[Input::get('main_category')] = ['main' => 1];

for ($i=1; $i<=4 ; ++$i) {
    $input = Input::get('category_'.$i);
    if ($input != '') {
            $categories[$input] = ['main' => 0];
    }
}



$entry->categories()->sync($categories);

$inTags = explode(',', trim( Input::get('tags'), ','));
$tags = [];

foreach ($inTags as $tag) {
    $tag = trim($tag);
    if ($tag == '') {
        continue;
    }
    $fTag = Tag::firstOrCreate(array('name' => $tag));

    $tags[$fTag->id] = ['entry_id' => $entry->id];
}
$entry->tags()->sync($tags);

在上面的代码中,我创建了条目(这里足以理解它,早期的代码并不重要),然后保存此条目所属的类别(使用数据透视表)并对标签执行相同的操作(但对于标签,如果标签不存在,我创建一个)。$entry->save()

但是,在插入数据后,两个数据透视表字段都保留默认值(可能相同,但我还没有测试过)。created_at0000-00-00 00:00:00updated_at

我是否需要以某种方式自动激活归档时间戳,还是需要我自己手动填写时间戳(但这可能意味着更多的编码和不使用)?sync


答案 1

为了在同步/附加关系时处理透视时间戳,您需要在关系定义中包含:belongsToManywithTimestamps()

// some model
public function someRelation()
{
  return $this->belongsToMany('RelatedModel')->withTimestamps();
}

然后,每个 // 将设置/更新数据透视表上的时间戳。syncattachupdateExistingPivot


答案 2

推荐