1

我正在使用带有 PropelBundle 的 Symfony2,假设我有以下架构:

<table name="person">
  <column name="id" type="INTEGER" primaryKey="true" autoIncrement="true" required="true"/>
  <column name="name" type="VARCHAR" size="100" required="true"/>
</table>
<table name="person_parent">
  <column name="person_id" type="INTEGER" primaryKey="true" required="true"/>
  <column name="parent_id" type="INTEGER" primaryKey="true" required="true"/>
</table>

考虑一个人可以有很多“父母”,就像父母可以有很多孩子“人”一样。“person_parent”表中的两列都是“person”表的外键。不像 Book/Author 这样的关系,可以在表“book_author”的模式中设置 isCrossRef="true" 以让 Propel 生成用于直接从作者类获取/设置/添加书籍对象的方法,反之亦然,用于父/子关系无法设置 isCrossRef="true",因此无法直接从“Person”对象获取/设置/添加父 Person 对象。换句话说,不可能做到:

$person = new Person();
$person->setPersonParents($personCollection);

设置任何给定人员的所有父“Person”对象的方法“setPersonParents()”不可用。但是,对于不引用同一个表(如 author_book)的交叉表,设置 isCrossRef="true" 允许以下操作:

$author = new Author();
$author->setBooks($bookCollection);

考虑到这一点,也不可能在“新人”表单中直接选择一个人的“父母”......

对于像朋友一样的关系,有EqualNestBehavior,它允许:

$person = new Person();
$person->setFriends($personCollection);

但是,该行为似乎不适用于父/子关系,因为它不关心层次结构(如果尝试获取任何给定“人”的“父母”,则将获得该“人”的所有“孩子”除了它的“父母”......)。这是人们对“朋友喜欢”的关系所期望的行为,其中一个人的朋友也是那个人的朋友。

有没有办法将EqualNestBehavior用于父/子案例?还是有任何其他推进行为或方法来处理这种关系?

4

1 回答 1

1

我不确定,EqualNestBehavior但您可以按以下方式设置工作流程。

在您的架构中,将 FK 定义为Person表:

<table name="person">
    <column name="id" type="INTEGER" primaryKey="true" autoIncrement="true" required="true"/>
    <column name="name" type="VARCHAR" size="100" required="true"/>
</table>
<table name="person_parent">
    <column name="person_id" type="INTEGER" primaryKey="true" required="true"/>
    <column name="parent_id" type="INTEGER" primaryKey="true" required="true"/>
    <foreign-key foreignTable="person" name="p1" onDelete="CASCADE" onUpdate="CASCADE">
        <reference local="person_id" foreign="id"/>
    </foreign-key>
    <foreign-key foreignTable="person" name="p2" onDelete="CASCADE" onUpdate="CASCADE">
        <reference local="parent_id" foreign="id"/>
    </foreign-key>
</table>

之后,当您生成模型时 - 您将获得以下方法:

$person = new Person();
$person->getPersonParentsRelatedByParentId();
$person->setPersonParentsRelatedByParentId($personCollection);

$person->getPersonParentsRelatedByPersonId();
$person->setPersonParentsRelatedByPersonId($personCollection);

设置者接受PropelCollection作为参数。

您只需要考虑这种情况,而不是像“获得父母”或“获得孩子”,而是考虑相关元素。

于 2012-08-23T05:37:33.473 回答