Eloquent sync和created_at / updated_at

时间:2014-09-26 12:33:59

标签: php laravel laravel-4 eloquent

我有以下代码:

$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)?

1 个答案:

答案 0 :(得分:42)

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

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

然后,每个sync / attach / updateExistingPivot都会设置/更新数据透视表上的时间戳。