簡體   English   中英

教義2:一對多關系;

[英]Doctrine2 :one-to-many relation;

我有2個具有一對多關系的實體: ArticleArticleCategory

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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM