时间戳记不适用于ORM和PostgreSQL数据库

时间戳记不适用于ORM和PostgreSQL数据库

本文介绍了时间戳记不适用于ORM和PostgreSQL数据库的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我在实体中添加了对 Timestampable 的支持,如下所示:使用Gedmo\Timestampable\Traits\TimestampableEntity; 。我已经通过运行 doctrine:schema:update --force 更新了数据库,但是任何时候我尝试插入新记录时都会收到以下消息:

I added support for Timestampable in my entity as follow: use Gedmo\Timestampable\Traits\TimestampableEntity;. I have updated my DB by running doctrine:schema:update --force but any time I try to insert a new record I get this message:

为什么?我正在使用最新的Symfony 2.5.3和PostgreSQL 9.2.9。这是完全错误:

Why? I'm using latest Symfony 2.5.3 and PostgreSQL 9.2.9. This is the complete error:

有任何建议吗?

已添加实体

<?php

use FOS\UserBundle\Model\User as BaseUser;
use Gedmo\Mapping\Annotation as Gedmo;
use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\Entity
 * @ORM\Table(name="usuarios_externos.usuarios", schema="usuarios_externos")
 * @Gedmo\SoftDeleteable(fieldName="deletedAt", timeAware=false)
 */
class Usuario extends BaseUser
{

    ....

    /**
     * @var datetime $created
     *
     * @Gedmo\Timestampable(on="create")
     * @ORM\Column(type="datetime")
     */
    private $created;

    /**
     * @var datetime $updated
     *
     * @Gedmo\Timestampable(on="update")
     * @ORM\Column(type="datetime")
     */
    private $updated;

    /**
     * @ORM\Column(name="deletedAt", type="datetime", nullable=true)
     */
    protected $deletedAt;

    ....

    public function getCreated()
    {
        return $this->created;
    }

    public function getUpdated()
    {
        return $this->updated;
    }

    public function setDeletedAt($deletedAt)
    {
        $this->deletedAt = $deletedAt;
    }

    public function getDeletedAt()
    {
        return $this->deletedAt;
    }

}


推荐答案

您应该在配置中启用时间戳记:

You should enable timestampable in your config:

stof_doctrine_extensions:
    orm:
        default:
            timestampable: true

这篇关于时间戳记不适用于ORM和PostgreSQL数据库的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-29 17:47