我有以下代码:
$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_at
字段在插入数据后保留默认值(0000-00-00 00:00:00
)(可能与updated_at
相同,但我没有对其进行测试)。
我是否需要以某种方式自动激活归档时间戳,或者需要我自己手动填写它们(但可能意味着更多编码而不使用sync
)?
答案 0 :(得分:42)
为了在同步/附加belongsToMany
关系时处理数据透视时间戳,您需要在关系定义中包含withTimestamps()
:
// some model
public function someRelation()
{
return $this->belongsToMany('RelatedModel')->withTimestamps();
}
然后,每个sync
/ attach
/ updateExistingPivot
都会设置/更新数据透视表上的时间戳。