Beziehungen zu Doctrine2 herstellen
Doctrine2 bietet zwei Mechanismen zum Verwalten von Beziehungen: Kaskadenlöschung und Datenbank- Durchsetzung von Ebenenbeschränkungen. Obwohl beide denselben Zweck erfüllen – das Löschen verwandter Entitäten, wenn eine übergeordnete Entität entfernt wird –, funktionieren sie unterschiedlich.
ORM-Ebenen-Kaskade:
Die ORM-Ebenen-Kaskade verwendet die Annotation cascade={"remove"}, wie sie in Ihrer Child-Entität zu sehen ist. Diese Option weist Doctrine2 an, untergeordnete Entitäten automatisch zu entfernen, wenn das übergeordnete Element gelöscht wird, jedoch nur im Kontext von Doctrines UnitOfWork. Es werden keine Datenbankeinschränkungen erstellt.
Einschränkungsdurchsetzung auf Datenbankebene:
Die Durchsetzung von Einschränkungen auf Datenbankebene wird durch Hinzufügen von onDelete="CASCADE" zum Foreign erreicht @ORMJoinColumn-Annotation der Schlüsselspalte. Dadurch wird die Datenbank angewiesen, untergeordnete Zeilen automatisch zu löschen, wenn eine zugehörige Zeile aus der übergeordneten Tabelle entfernt wird. Um diese Option in Ihrer untergeordneten Entität zu implementieren, ändern Sie die Annotation @ORMJoinColumn wie folgt:
<code class="php">@ORM\JoinColumn(name="father_id", referencedColumnName="id", onDelete="CASCADE")</code>
Kaskadenverhalten verstehen:
Es ist wichtig zu beachten, dass das Kaskadenverhalten funktioniert nur in eine Richtung. In Ihrer aktuellen Konfiguration ist die Kaskade so eingestellt, dass untergeordnete Elemente entfernt werden, wenn das übergeordnete Element gelöscht wird (cascade={"remove"} in Child). Das Löschen eines untergeordneten Elements löst jedoch nicht die Löschung des übergeordneten Elements aus. Wenn Sie dieses Verhalten wünschen, müssen Sie die Kaskadeneinstellung umkehren oder eine OneToMany-Beziehung mit orphanRemoval=true in Father` verwenden.
Wenn Sie die Unterschiede zwischen diesen Kaskadenmechanismen verstehen, können Sie Beziehungen in Doctrine2 und effektiv herstellen Stellen Sie sicher, dass zugehörige Daten gemäß Ihren Geschäftsanforderungen konsistent gelöscht werden.
Das obige ist der detaillierte Inhalt vonKaskadenlöschung in Doctrine2: Einschränkungen auf ORM-Ebene vs. Datenbankebene?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!