本文介绍了时间戳记不适用于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数据库的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!