Doctrine2 实体关系

发布于 2024-12-15 15:09:43 字数 463 浏览 1 评论 0原文

我是 Symfony2 的新手(几年前使用过 symfony 1.xa),我试图了解如何使用 Doctrine2 处理实体关系。 (顺便说一句,如果 Symfony2 书中有更多关系示例而不是简单地引用 Doctrine2 文档,那就太好了:-)

所以我有一个简单的产品实体,我想将其与多个类别相关(即单个产品可以属于多个类别) )。从表面上看,这看起来像是一对多的关系,但我认为这样的关系将通过数据库中的联接表来完成。所以我做了这样的事情:

class Product
{
  ....

  /**
   * @ORM\ManyToMany(targetEntity="Category");
   **/
  private $categories;

}

进行架构更新确实按预期在数据库中创建了连接表。但我想知道我将其设为多对多是否错误?我想我是在问最佳实践以及您将如何做到这一点?任何人都可以提供建议和/或提供示例吗?

Im new to Symfony2 (having used symfony 1.x a couple years ago) and Im trying to understand how to handle entity relationships with Doctrine2. (Incidently, it would be nice if the Symfony2 book had more relationship examples instead of simply referring to the Doctrine2 docs :-)

So I have a simple product entity that I want to relate to multiple categories (i.e. single product can be in multiple categories). On the surface this looks like a one-to-many kind of relationship right, but Im thinking a relationship like that would be done via a join table in the database. So Im doing something like this instead:

class Product
{
  ....

  /**
   * @ORM\ManyToMany(targetEntity="Category");
   **/
  private $categories;

}

Doing a schema update does indeed create the join table in the database as expected. But Im wondering if Im wrong in making this a many-to-many instead ? I guess Im asking about best practices and how you would do this ? Can anyone advise and/or provide examples ?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

一枫情书 2024-12-22 15:09:43

您的句子“单一产品可以属于多个类别”是正确的,但这句话也是正确的:“多个产品可以属于多个类别”。那是因为你没有使用好的句子,即:

  • “一个类别可以有许多产品”
  • “一个产品可以有许多类别”

这意味着你有很多一对多关系。

如果是

  • “一个类别可以有许多产品”
  • “一个产品只能有一个类别”

那么你就会有一个一对多和一个多对- 一种关系。

Your sentence "single product can be in multiple categories" is true but this one is true too : "multiple products can be in multiple categories". That's because you're not using the good sentences, which are:

  • "a category can have many products"
  • "a product can have many categories"

This means you have a many-to-many relationship.

If it were

  • "a category can have many products"
  • "a product can have only one category"

Then you'd have a one-to-many and a many-to-one relationship.

独留℉清风醉 2024-12-22 15:09:43

如果你想要多对多关系,你将需要一个中间表

class Product
{
    /**
     * @ManyToMany(targetEntity="Categories")
     * @JoinTable(name="Product_Category",
     *      joinColumns={@JoinColumn(name="product_id", referencedColumnName="id")},
     *      inverseJoinColumns={@JoinColumn(name="Category_id", referencedColumnName="id")}
     *      )
     */
    private $categories;
}

If you want a many to many relationship you will need an intermediate table

class Product
{
    /**
     * @ManyToMany(targetEntity="Categories")
     * @JoinTable(name="Product_Category",
     *      joinColumns={@JoinColumn(name="product_id", referencedColumnName="id")},
     *      inverseJoinColumns={@JoinColumn(name="Category_id", referencedColumnName="id")}
     *      )
     */
    private $categories;
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文