如何在数据透视表中设置日期列格式?

时间:2014-06-20 08:42:35

标签: php laravel laravel-4 pivot-table

我在数据透视表上的Laravel中遇到日期字段格式问题。 我想要实现的是使用" created_at"和" updated_at" Unix时间格式 INT(11)中的字段而不是TIMESTAMP。 我也尝试使用自定义Pivot,但没有任何运气。到目前为止代码工作正常,但它使用的是时间戳而不是Unix。

在我的代码中,我这样做:

//[.. other stuff ...]

//update the relation wich references current user and group 1

$user->groups()->sync(array(1 => array('newsletter' => $newsletter)));

这是我的代码:

use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Relations\Pivot;

class User extends Model{
    public function groups() {
        return $this->belongsToMany('Group')->withTimestamps();
    }

    public function newPivot(Eloquent $parent, array $attributes, $table, $exists) {
        if ($parent instanceof Group) {
            return new UserGroup($parent, $attributes, $table, $exists);
        }
        return parent::newPivot($parent, $attributes, $table, $exists);
    }
}

class Group extends Model {
    public function users() {
        return $this->belongsToMany('User')->withTimestamps();
    }

    public function newPivot(Eloquent $parent, array $attributes, $table, $exists)
{
        if ($parent instanceof User) {
            return new UserGroup($parent, $attributes, $table, $exists);
        }
        return parent::newPivot($parent, $attributes, $table, $exists);
    }
}

class UserGroup extends Pivot 
{
protected function getDateFormat()
{
    return 'U';
}

public function getDates()
{
    return array(
    'created_at',
    'updated_at');
}
    public function user() {
    return $this->belongsTo('User');
}

public function group() {
    return $this->belongsTo('Group');
}

}

感谢您的关注。

0 个答案:

没有答案