我有文章,属于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)