[英]Doctrine2 :one-to-many relation;
我有2个具有一对多关系的实体: Article
和ArticleCategory
class Article {
/**
* @var integer
*
* @ORM\Column(name="rate", type="integer",options={"default" : 0})
*/
private $rate = 0;
/**
* @var \ArticleCategory
*
* @ORM\ManyToOne(targetEntity="ArticleCategory",inversedBy="articles")
* @ORM\JoinColumn(name="article_category_id", referencedColumnName="id")
*/
private $category;
}
class ArticleCategory {
/**
*
* @var \Article
* @ORM\OneToMany(targetEntity="Article", mappedBy="category")
*/
protected $articles;
}
现在,我想获取类别中有很多具有最高评分的文章。
“我的意思是,其中排名最高的N个类别是按评分最高的文章排序的 ( 这些 类别中的文章的比率高于平均比率 )
我怎样才能做到这一点?
终于我找到了这个问题,也许对其他人有用! :)
$query = $em->createQuery('SELECT c, avg(a.rate) x
FROM YoutabsGeneralModelBundle:ArticleCategory c
JOIN c.articles a
GROUP BY c.id
ORDER BY x DESC');
我添加ORDER BY
是因为我想对此设置限制:
$query->setMaxResults($limit);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.