Al usar Doctrine2 y PostgreSQL, necesito crear restricciones de clave externa APLAZABLE e INICIALMENTE APLAZADA
Se encontraron opciones "aplazables" y "aplazadas" en Doctrine/DBAL/Platforms/PostgreSqlPlatform.php, pero no tengo idea de dónde usarlas dentro de las anotaciones de la Entidad.
<?php /** * Class User * * @ORM\Table(name="jira_issues_changelogs") * @ORM\Entity * @package JiraBundle\Entity\Issue */ class Changelog { /** * @var string * * @ORM\Column(name="id", type="integer") * @ORM\Id * @ORM\GeneratedValue(strategy="NONE") */ protected $id; /** * @ORM\ManyToOne(targetEntity="\JiraBundle\Entity\Issue", inversedBy="changelog") * @ORM\JoinColumn(name="issue", referencedColumnName="id") Need this column foreign key to be DEFERRABLE INITIALLY DEFERRED */ protected $issue;
Encontré este mismo problema con una aplicación en la que estaba trabajando y llegué a la conclusión de que el soporte DEFERRABLE en Doctrine DBAL no está expuesto a Doctrine ORM.
El quid del problema es que en la herramienta SchemaTool de ORM, el método de recopilación de relaciones unidas a columnas () no descubre ninguna $fkOption excepto onDelete. Para admitir la adición de 'aplazable', se necesitaría una sintaxis extendida en la capa de mapeo ORM para ello.
En mi caso, fue más fácil parchear SchemaTool para agregarlo que coordinar con upstream para agregarlo correctamente, ya que hay muy pocas referencias a personas que desean usar opciones avanzadas de FK en Google.
Pensé en arrojar una respuesta aquí para evitar que otras personas tengan que rastrear el problema por sí mismas...
Si alguien quiere presentar un problema de Doctrine ORM al respecto, ¡sea mi invitado!