0

カテゴリに属する​​ 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)
4

1 に答える 1

0

WHERE 句のこの部分が原因で、複数の作成者を含むカテゴリの完全なリストを作成することはできませんでした。

OR (a.author_id IS NULL)

カテゴリの完全なリストを取得するために、それを削除し、2 つ目のクエリを含める必要がありました。

次に、PHP (または同様のもの) を使用して各カテゴリをループし、そのループ内で各記事をループして、その特定の著者のすべてのカテゴリと記事を含む新しい配列/オブジェクトを作成します。

if(is_array($categories)) {
    if(is_array($articles)) {
        foreach($categories as $ck => $cv) {
            $category_set = false;
            foreach($article as $ak => $av) {
                if($av['category_name'] == $cv['category_name']) {
                    $articles_by_category[] = $article[$ak];
                    $category_set = true;
                    unset($article[$ak]);
                }
            }
            if($category_set == false) {
                $articles_by_category[] = $categories[$ck];
            }
        }
        $articles = $articles_by_category;
        unset($articles_by_category);
    } else {
        $articles = $categories;
    }
}

ただし、純粋な MySQL ソリューションを誰かが持っているかどうかを確認することは興味深いでしょう。

于 2012-08-24T08:25:16.453 に答える