• Jobs
  • About Us
  • Jobs
    • Home
    • Jobs
    • Courses and challenges
  • Businesses
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

307
Views
Cómo hacer que Doctrine PostgreSQL Foreign Key restrinja APLAZABLE

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;
over 3 years ago · Santiago Trujillo
1 answers
Answer question

0

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!

over 3 years ago · Santiago Trujillo Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Show me some job opportunities
There's an error!