我有文章,属于article_types,属于类别。每篇文章都有一个格式。
我想按类别列出特定作者发表的所有文章。
我想显示所有类别,即使是没有文章的类别。
所有文章都有一个 article_type 并且所有类别都包含文章类型。
我有一个在 MySQL 5.5.x 上完美运行但在 5.0 上运行良好的查询。这是一个 MySQL 错误,还是应该更改查询或两者兼而有之?
SELECT
a.article_id, a.article_time, a.article_notes f.format_name, at.article_type_name, c.category_name, c.category_description
FROM
article AS a
LEFT JOIN article_type AS at ON at.advice_id = a.advice_id
LEFT JOIN format AS f ON f.format_id = a.format_id
RIGHT JOIN category AS c ON c.category_id = at.cateory_id
WHERE
(a.author_id = 5 AND a.published = 1)
OR (a.author_id IS NULL)
ORDER BY
c.category_name ASC, a.article_time DESC
所需的输出(在简单的 php 循环之后):
Category 1
Article A (Article Type I) (Digital)
Article B (Article Type I) (Print)
Article E (Article Type II) (Digital)
Category 2
Category 3
Article H (Article Type V) (Audio)
Article M (Article Type IV) (Print)