与学说 gedmo 可记录扩展和 stof 学说扩展有关的问题
config/doctrine/Tag.orm.xml
<doctrine-mapping xmlns="http://doctrine-project.org/schemas/orm/doctrine-mapping"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://doctrine-project.org/schemas/orm/doctrine-mapping
https://raw.github.com/doctrine/doctrine2/master/doctrine-mapping.xsd"
xmlns:gedmo="http://gediminasm.org/schemas/orm/doctrine-extensions-mapping"
>
<entity name="App\Entity\Tag" table="tag">
<id name="id" type="integer" column="id">
<generator strategy="AUTO"/>
</id>
<field name="tag" type="string" length="50" unique="true" />
<field name="text" type="string" length="2000" nullable="true">
<gedmo:versioned/>
</field>
<gedmo:loggable log-entry-class="App\Entity\LogEntry"/>
</entity>
配置/包/stof_doctrineextensions.yaml
stof_doctrine_extensions:
default_locale: en_US
orm:
default:
loggable: true
这有效(更新中)
$tag = $em->getRepository(Tag::class)->findOneBy(['tag'=>'test']);
$tag->setTag('test update');
$tag->setText('test text');
$em->flush();
这不(坚持)
$tag = new Tag();
$tag->setTag('test');
$tag->setText('test text');
$em->persist($tag);
$em->flush();
**Throws below exception**
An exception occurred while executing 'INSERT INTO log_entry (action, logged_at, object_id,
object_class, version, data, username, comment, created_by_id, updated_by_id) VALUES (?, ?, ?,
?, ?, ?, ?, ?, ?, ?)' with params ["create", "2018-10-01 17:22:28", null, "App\\Entity\\Tag", 1, "a:1:
{s:4:\"text\";N;}", null, null, null, null]:
SQLSTATE[23000]: Integrity constraint violation: 1048 Column 'object_id' cannot be null
其明显的可记录侦听器无法访问新对象 ID,或者试图在保留原始对象之前保留日志条目。我尝试调试似乎永远不会在持久化时调用LoggableListener
'spostPersist
方法,但在更新时有效。