Doctrine 2.1 - значение по умолчанию для столбца даты и времени - PullRequest
35 голосов
/ 08 октября 2011

Может кто-нибудь сказать мне, как добавить значение по умолчанию в столбце datetime?Я не могу сделать это так:

protected $registration_date = date("Y-m-d H:i:s", time());

Так как?

Ответы [ 7 ]

53 голосов
/ 14 декабря 2015

Для значения по умолчанию CURRENT_TIMESTAMP:

     @ORM\Column(name="created_at", type="datetime", options={"default": "CURRENT_TIMESTAMP"})

Или для более старых версий Symfony:

     @ORM\Column(name="created_at", type="datetime", options={"default": 0})

Работало для меня ... Однако это работает только с MySQL .

53 голосов
/ 09 октября 2011

Вы также можете использовать обратные вызовы жизненного цикла, если хотите быть очень точными:

use Doctrine\ORM\Mapping as ORM;

/**
 * @ORM\HasLifecycleCallbacks
 * ...
 */
class MyEntity
{
    /**
     * @ORM\PrePersist
     */
    public function onPrePersistSetRegistrationDate()
    {
        $this->registration_date = new \DateTime();
    }
}
36 голосов
/ 08 октября 2011

Вы отображаете свое свойство как тип DateTime, а затем устанавливаете значение в конструкторе, используя новый экземпляр DateTime:

/**
 * @Entity
 * @Table(name="...")
 */
class MyEntity
{
    /** @Column(type="datetime") */
    protected $registration_date;

    public function __construct()
    {
        $this->registration_date = new DateTime(); 
    }
}

Это работает, поскольку конструктор персистентного класса не вызывается при гидратации.

21 голосов
/ 22 сентября 2013

Для этого автоматизировано расширение ...

https://github.com/l3pp4rd/DoctrineExtensions/blob/master/doc/timestampable.md

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

    /**
     * @var \DateTime
     *
     * @ORM\Column(name="date_modified", type="datetime")
     * @Gedmo\Timestampable(on="update")
     */
    private $date_modified;
19 голосов
/ 05 июля 2016

Думаю, лучший способ выполнить автозаполнение для datetime - сделать так:

* @ORM\Column(type="datetime", options={"default"="CURRENT_TIMESTAMP"})

Размещение логики в конструкторе не является правильным решением, поскольку установки значений по умолчанию Ответственность клиента SQL . Если вы решите больше не использовать ORM - вы потеряете бизнес-логику. Кроме того, если вы используете конструктор, вы не сможете добавить временные метки по умолчанию к атрибутам datetime для существующих строк .

3 голосов
/ 13 марта 2018
@var string @ORM\Column(name="login_at", type="datetime", options={"default" = "CURRENT_TIMESTAMP"})

Это будет работать.Просто опубликовать для будущего ссылки.

0 голосов
/ 24 января 2019

Работа для меня с MySql и Symfony 3.4.

...
fields:
    start_date:
        type: date
        nullable: false
        options:
            default: '1910-01-01'
            comment: 'The default date is 1910-01-01'
...
...