sql >> Database >  >> RDS >> Mysql

Element invoegen in leerstellige luisteraar

Want wanneer onFlush wordt aangeroepen, zijn alle wijzigingen al berekend en moet u ze vernieuwen als u van entiteit verandert of een nieuwe entiteit aanmaakt.

$em = $this->getEntityManager();
$uow = $em->getUnitOfWork();
$logMetadata = $em->getClassMetadata('Your\LogClass');
...
$em->persist($log);
$uow->computeChangeSet($logMetadata, $log);

Voor postPersist:

$em = $this->getEntityManager();
$uow = $em->getUnitOfWork();
$log = new Log;
...

$logMetadata = $em->getClassMetadata('Your\LogClass');
$className = $logMetadata->name;
$persister = $this->getEntityPersister($className);
$persister->addInsert($log);
$uow->computeChangeSet($classMeta, $logEntry);
$postInsertIds = $persister->executeInserts();

if ($postInsertIds) {
    foreach ($postInsertIds as $id => $entity) {
        $idField = $logMetadata->identifier[0];
        $logMetadata->reflFields[$idField]->setValue($entity, $id);
        $this->addToIdentityMap($entity);
    }
}



  1. Zijn PostgreSQL-kolomnamen hoofdlettergevoelig?

  2. Query voor PHP/MySql EN/OF voor een geavanceerde zoekopdracht

  3. Beperkingen voor externe sleutels:wanneer moet u ON UPDATE en ON DELETE gebruiken?

  4. Wat is MySQL's wait_timeout, net_read_timeout en net_write_timeout variabele?