gpt4 book ai didi

php - Where-ing 在歧视表中

转载 作者:行者123 更新时间:2023-12-02 07:04:23 27 4
gpt4 key购买 nike

如何选择来自一位特定作者的所有项目?可能这样吗?或者,如果我也想要很多项目类型和项目包(项目有很多项目),我该如何编辑实体?

元素

/**
* @ORM\Table()
* @ORM\Entity
* @ORM\InheritanceType("JOINED")
* @ORM\DiscriminatorColumn(name="discr", type="string")
* @ORM\DiscriminatorMap({
* "cd" = "ItemCD",
* "dvd" = "ItemDVD",
* "pack" = "ItemPack",
* })
*/
class Item
{

/**
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;

/**
* @ORM\Column(name="name", type="string", length=250, nullable=false)
*/
private $name;

}

元素CD

/**
* @ORM\Table()
* @ORM\Entity
*/
class ItemCD extends Item
{

/**
* @ORM\ManyToOne(targetEntity="Author", inversedBy="item")
* @ORM\JoinColumn(name="author_id", referencedColumnName="id")
*/
private $author;

}

元素DVD

/**
* @ORM\Table()
* @ORM\Entity
*/
class ItemDVD extends Item
{

/**
* @ORM\ManyToOne(targetEntity="Author", inversedBy="item")
* @ORM\JoinColumn(name="author_id", referencedColumnName="id")
*/
private $author;

}

元素包

/**
* @ORM\Table()
* @ORM\Entity
*/
class ItemPack extends Item
{

/**
* @ORM\ManyToMany(targetEntity="Item", inversedBy="item")
* @ORM\JoinTable()
*/
private $items;

}

作者

/**
* @ORM\Table()
* @ORM\Entity
*/
class Author
{

/**
* @ORM\Column(name="id", type="integer", nullable=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*
*/
private $id;

/**
* @ORM\Column(name="name", type="string", length=250, nullable=false)
*/
private $name;

}

最佳答案

您必须查询特定元素。这是一个已知的(也是想要的)限制,因为 DQL 是一种静态类型语言:参见 http://www.doctrine-project.org/jira/browse/DDC-16

相关:how to access fields in inherited table in doctrine2 / dql query

解决此问题的一种方法是在您的 DQL 中使用 2 个子查询:

SELECT
i
FROM
Item i
WHERE
i.id IN(
SELECT
i2.id
FROM
ItemDvd i2
WHERE
i2.author = :author
)
OR
i.id IN(
SELECT
i3.id
FROM
ItemCd i3
WHERE
i3.author = :author
)

如您所见,您必须手动提取每个可能的子类型的标识符。

编辑:要获取给定作者的所有包(连同单张 DVD 或 CD),查询变得更糟:

SELECT
i
FROM
Item i
WHERE
i.id IN(
SELECT
i2.id
FROM
ItemDvd i2
WHERE
i2.author = :author
)
OR
i.id IN(
SELECT
i3.id
FROM
ItemCd i3
WHERE
i3.author = :author
)
OR
i.id IN(
SELECT
i4.id
FROM
ItemPack i4
JOIN
i4.items i5
WHERE
i5.id IN (
SELECT
i6.id
FROM
Item i6
WHERE
i6.id IN(
SELECT
i7.id
FROM
ItemDvd i7
WHERE
i7.author = :author
)
OR
i6.id IN(
SELECT
i8.id
FROM
ItemCd i8
WHERE
i8.author = :author
)
)
)

关于php - Where-ing 在歧视表中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14851602/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com