sql >> Databáze >  >> RDS >> Mysql

Klauzule GROUP BY s aliasem?

AKTUALIZOVÁNO 2

  1. Zdá se, že do GROUP BY nemusíte zahrnout TotalSales. Když se podívám na váš dotaz, nedává to žádný smysl. Prostě to vypusťte z vnitřního výběru.

  2. Chcete-li zahrnout knihy, které nebyly prodány, musíte použít vnější spojení

Jak bylo řečeno, váš dotaz může vypadat takto

SELECT COALESCE(author_id, 'All Authors') author_id
     , COALESCE(book_id, IF(author_id IS NULL, 'All Books', 'Subtotal')) book_id
     , COALESCE(total_quantity, 'No books') total_quantity
     , COALESCE(total_sales, 'No Sales') total_sales   
 FROM 
(    
 SELECT author_id 
      , b.book_id 
      , SUM(quantity) total_quantity  
      , SUM(quantity * order_price) total_sales   
   FROM book_authors b LEFT JOIN order_details d
     ON b.book_id = d.book_id
  WHERE author_sequence = 1           
  GROUP BY Author_id, Book_ID WITH ROLLUP  -- you don't need TotalSales here
) q;

Ukázkový výstup:

+-------------+-----------+----------------+-------------+
| author_id   | book_id   | total_quantity | total_sales |
+-------------+-----------+----------------+-------------+
| 1           | 1         | 12             | 278.50      |
| 1           | 3         | No books       | No Sales    |
| 1           | Subtotal  | 12             | 278.50      |
| 3           | 2         | 5              | 75.75       |
| 3           | Subtotal  | 5              | 75.75       |
| All Authors | All Books | 17             | 354.25      |
+-------------+-----------+----------------+-------------+

Zde je SQLFiddle demo



  1. Součet hodnot podle měsíce v milisekundách

  2. Je při vytváření uložené procedury vyžadován `definer`?

  3. Odstraňte opakované výsledky z dotazu MySQL

  4. Co ve skutečnosti znamená číslo v závorce?