sql >> Database >  >> RDS >> Mysql

MySQL select sum met group by en lege waarden

U kunt dit gebruiken:

SELECT b.store_id, b.group_hour, IFNULL(sales_sum, 0) AS sales_sum
FROM 
(
 SELECT store_id, HOUR(sales_date) as group_hour, sum(sales_amount) as sales_sum 
 FROM sales 
 GROUP BY store_id, group_hour
) a
RIGHT OUTER JOIN 
(
  SELECT *
  FROM
  (
   SELECT DISTINCT store_id
   FROM sales
  ) all_stores
  CROSS JOIN
  (
   SELECT 10 as group_hour
   UNION ALL
   SELECT 11
   UNION ALL
   SELECT 12
   UNION ALL
   SELECT 13
   UNION ALL
   SELECT 14
   UNION ALL
   SELECT 15
  ) all_hours
) b
ON a.store_id = b.store_id AND a.group_hour = b.group_hour
ORDER BY 1, 2

Ik gebruik RIGHT OUTER JOIN met de tabel die alle winkels en alle uren bevat (van 10 tot 15).




  1. Mysql COUNT(*) op meerdere tabellen

  2. Gebruik PostgreSQL SSL-verbinding in roest met zelfondertekende certificaten

  3. Hoe LOWER() werkt in MariaDB

  4. Hoe maak ik verbinding met een MSSQL-database met behulp van Perl's DBI-module in Windows?