繁体   English   中英

Doctrine SoftDelete OneToOne Relationship

[英]Doctrine SoftDelete OneToOne Relationship

我的代码上有这些实体。

class Review extends BaseEntity {

    /** @ORM\OneToOne(targetEntity="Action", mappedBy="review") */
    protected $action;
}


class Action extends BaseEntity {

    /** @ORM\OneToOne(targetEntity="Review", inversedBy="action") */
    protected $review;
}

正如您所看到的,它是Action和Review之间的OneToOne关系。 我的问题是我也为我的实体使用软删除,所以当我删除一个实体实际上没有被删除时,只设置了一个删除日期。 稍后在审计跟踪中,我需要显示已删除的评论,当然我还需要来自父操作的信息。 我的问题是,我是否需要与OneToMany建立这种关系? 还是有更好的方法?

说实话,我不太了解软删除行为。 您需要注意的是,软删除实体是关系数据库中的一个强大妥协。

您可能希望在此特定实例中考虑事件采购方法。 我建议在基于文档的数据库中存储有关删除和(软)删除实体的信息。

任何其他方法(如OneToMany )仍然可以,但请记住,这里的风险是通过引入不连贯的关系来降低您的关系。

话虽如此,我完全清楚现实生活与理论完全不同:)祝你好运。

问候。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM