Timestampable不ORM和PostgreSQL数据库工作(Timestampable do

2019-10-20 18:52发布

我添加了支持Timestampable在我的如下实体: use Gedmo\Timestampable\Traits\TimestampableEntity; 。 我已经通过运行更新我的DB doctrine:schema:update --force ,但任何时候,我尝试插入一个新的记录我得到这个消息:

SQLSTATE [23502]:非空违反:7错误:在列“createdat”空值违反非空约束

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

在执行“INSERT INTO usuarios_externos.usuarios(用户名,username_canonical,电子邮件,email_canonical,启用,盐,密码,LAST_LOGIN,锁定,过期expires_at,confirmation_token,password_requested_at,角色,credentials_expired,credentials_expire_at,ID,角色,correo_alternativo发生异常, telefono,telefono_movil,传真,pagina_web,direccion,deletedAt,createdAt,updatedAt,pais_id,estado_id,municipio_id,ciudad_id,parroquia_id)VALUES(?,?,?,?,?,?,?,?,?,?,?, ?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?,?)”使用参数[ “reynier”, “reynier”, “reynierpm@gmail.com”, “reynierpm@gmail.com”, “假”, “hhm95if1uog88koggos48csk48k0w80”, “sVzbTOHgZzhU92zPHBFsVG3GqV + DO5xvXxvNdC5 / GVJ / Hnvlm8rBsNDsIgPKYXdZ4NcnONqXnrOB6UR + lAluAw ==”,NULL, “假”,“假”,NULL,NULL,NULL, “A:0:{}”, “假”,NULL,3, “真”, “reynierpm1@gmail.com”, “021245678999”, “”, “”, “”, “sadasdasd”,NULL,NULL,NULL,23,1,1,1,22]

有什么建议?

新增实体

<?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;
    }

}

Answer 1:

你应该能够在你的配置timestampable:

stof_doctrine_extensions:
    orm:
        default:
            timestampable: true


文章来源: Timestampable does not work with ORM and PostgreSQL database