- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在使用 Doctrine 2 的实体之间的级联关系时遇到了问题。
我有一个与父事件相关的 Media
实体:
class Media
{
/**
* @ORM\OneToOne(targetEntity="Event", mappedBy="media")
*/
private $event;
public function getEvent()
{
return $this->event;
}
public function setEvent(Event $event)
{
$this->event = $event;
}
}
每个事件
都与媒体(双向)相关,也与导入
实体相关。
class Event
{
/**
* @ORM\JoinColumn(name="media", referencedColumnName="id", onDelete="SET NULL")
* @ORM\OneToOne(targetEntity="Media", inversedBy="event", cascade={"persist", "remove"}, orphanRemoval=true)
*/
private $media;
public function getMedia()
{
return $this->media;
}
public function setMedia(Media $media = null)
{
$this->media = $media;
}
/**
* @ORM\JoinColumn(name="import", referencedColumnName="id", nullable=true, onDelete="CASCADE")
* @ORM\ManyToOne(targetEntity="Import")
*/
private $import;
public function getImport()
{
return $this->import;
}
public function setImport(Import $import = null)
{
$this->import = $import;
}
}
预期行为如下:
Event
实体在其父 Import
被删除时会自动删除(与 onDelete="CASCADE"
的 ManyToOne 关系)。Event
实体还包含对 Media
实体的引用(OneToOne 关系),删除事件时必须删除该实体。两者都运行良好:
但是,如果我删除导入,虽然事件被删除,但与已删除事件相关的媒体不会。
对可能发生的事情有什么想法吗?谢谢!
最佳答案
您所描述的问题是预期的行为。 onDelete="CASCADE"
选项强制执行由数据库内部执行的行为,而选项 cascade={"remove"}
通过 Doctrine 处理并应用于以下对象:如所述 in the documentation 在内存中执行:
Cascade operations are performed in memory. That means collections and related entities are fetched into memory (even if they are marked as lazy) when the cascade operation is about to be performed. This approach allows entity lifecycle events to be performed for each of these operations.
这两种方法都是有效的,但它们意味着不同的事情,如所讨论的 in this section .
您的设置实际发生的情况是,您希望在您的场景中混合使用 onDelete="CASCADE"
和 cascade={"remove"}
一起操作,这由于其本性,他们不能。
事实上,由于 Import
中没有 cascade={"remove"}
的反面,当您删除 Import
:
Import
对应的表执行DELETE
操作事件
的外键,与您的导入
相关的事件将被直接在数据库中删除从那里开始,不会执行任何其他操作,因为用于 Media
的表没有任何引用 Event
表的外键(因为它位于协会)。
您可以执行以下两件事来实现此目的:
Media
表上添加 onDelete="CASCADE"
在Media.php
/**
* @ORM\OneToOne(targetEntity="Event", inversedBy="media")
* @ORM\JoinColumn(onDelete="CASCADE")
*/
private $event;
在Event.php
/**
* @ORM\OneToOne(targetEntity="Media", mappedBy="event")
*/
private $media;
通过这种方法,删除数据库中的 Import
条目必然会删除相关的 Event
条目,并且通过相同的机制,相关的 Media
将被删除。被删除(所有这些都是由您的数据库直接完成的,Doctrine 只是在 Import
表上发出了一个 DELETE
操作)。
Import
中添加反面并使用cascade={"remove"}
如果使用 cascade={"remove"}
在 Import
中添加反向 OneToMany
,则使用实体管理器执行的删除操作将是级联到相关的 Event
实体,该实体还将删除操作级联到任何关联的 Media
。
如果您希望为这些实体执行生命周期事件,这会很有用。
这并不意味着您必须在两种方法之间进行选择。该文档说明如下:
You should be aware however that using strategy 1 (CASCADE=REMOVE) completely by-passes any foreign key onDelete=CASCADE option, because Doctrine will fetch and remove all associated entities explicitly nevertheless.
话虽这么说,如果您希望数据库保持正确的状态,那么除了 cascade={"remove"}
之外,还有 onDelete=CASCADE
是有意义的。例如,如果您直接执行DELETE
查询(不使用实体管理器),则在没有onDelete=CASCADE
的情况下不会删除相关条目,并且您的RDBMS很可能会提示无效外键约束。
关于php - 通过 onDelete 删除实体时 Doctrine Cascade={remove} 不起作用 ="CASCADE",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48852654/
都是整数,但一直报错 "Only assignment, call, increment, decrement, await, and new object expressions can be us
我有以下情况:一个“对话”实体/表,它有多个关联的标签。Tag 也是一个实体/表 - key/id 是 tagName(一个字符串)。 在客户端 (javascript),我在处理标签时使用字符串数组
我想通过 maven java 源代码生成器自动生成 java 源代码。我想通过查看一个大实体 xml 文件来创建实体类,该文件将包含系统中的所有实体和实体关系。据我搜索,目前maven中没有这样的插
我有一段时间有这个疑问,有人说 EJB 3.0 中没有所谓的实体 bean。有没有可能这样说,EJB 3.0 使用 JPA 来持久化数据并且没有对以前版本(EJB 2.1)中的实体 bean 进行增强
我观看了关于 Core Data 的 2016 WWDC 视频并查看了各种教程。我见过使用 Core Data Framework 创建对象以持久保存到 managedObjectContext 中的
实体(entites) 用于定义引用普通文本或特殊字符的快捷方式的变量,可在内部或外部进行声明 实体引用是对实体的引用 声明一个内部实体 语法: <!ENTITY 实体名称 "
This page建议 !ENTITY: If you want to avoid duplication, consider using XML entities (for example, [ ]
我正在努力解决这个问题:如何判断一个概念是聚合根还是只是一个实体(属于 AR 的一部分)? : 他们都有 ID 它们都是由实体或值对象组成 也许如果我需要引用其他 AR 中的实体,那么我需要将其设为
我使用 Symfony2 和 Doctrine,我有一个关于实体的问题。 出于性能方面的考虑,我想知道是否可以在不进行所有关联的情况下使用实体? 目前,我还没有找到另一种方法来创建继承带有关联的类的模
我已经尝试在 HTML 中包含以下代码,用于附加文件符号。但它显示一个空的白框。 📎 📎 📎 是否有替代的 HTML 附加文件符号实体? 如果没有,我们可以手动创建
我在 grails 中有一个域类......我如何让 gorm 在创建数据库时忽略这个实体?就别管它了。 最佳答案 如果我理解,你不想从域类创建表?如果是,请在域类中使用此代码: static map
我正在努力解决这个问题:如何判断一个概念是聚合根还是只是一个实体(属于 AR 的一部分)? : 他们都有 ID 它们都是由实体或值对象组成 也许如果我需要引用其他 AR 中的实体,那么我需要将其设为
我已经尝试在 HTML 中包含以下代码,用于附加文件符号。但它显示一个空的白框。 📎 📎 📎 是否有替代的 HTML 附加文件符号实体? 如果没有,我们可以手动创建
如何在我的实体中以 14-04-2017 格式存储日期? 但我必须从字符串中解析它。 SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-
我需要从两个连接表中获取数据。数据集是什么类型?我是否需要创建一个包含这两个表中的属性的类以用于数据集类型,或者我可以使用实体模式中的类型。我如何修改我的方法才能正常工作? public static
好的,我们正在尝试建立一个中央站点来查看来自销售我们产品的多个供应商的数据。这些多个供应商使用不同的销售系统(确切地说是两个不同的系统),因此每个数据库看起来完全不同。我们与他们的数据库同步,因此数据
我是 backbone 的新手。但是当我研究模型实体时,我不明白一些事情。如果我们可以像 java 或 C# 这样的标准语言一样定义模型属性,那就太好了。有没有可能是这样的。所以我的想法是这样的: M
我想获取存储在可绘制的 xml 文件中的形状的颜色。 我来到了将 Drawable 存储在 Drawable 变量中的步骤,所以,现在我想获取形状的颜色(纯色标签)。 有什么建议吗? 最佳答案 Gra
实体是直接映射到我们的数据库(我们用于 Hibernate)的类。 在调用 DAO 之前,我们的服务类包含这些实体的业务逻辑。 我们还有命令对象,它们是与特定 View 相关的 POJO。有人告诉我实
在我的应用程序中,我需要显示不同存储过程返回的记录列表。每个存储过程返回不同类型的记录(即列数和列类型不同)。 我最初的想法是为每种类型的记录创建一个类,并创建一个函数来执行相应的存储过程并返回 Li
我是一名优秀的程序员,十分优秀!