Mysql
 sql >> Base de données >  >> RDS >> Mysql

Compter les données de plusieurs tables à l'aide de SUM

Au lieu de rejoindre tbl_workers vous pouvez joindre à sa variante non pivotée où position et position2 seraient dans la même colonne mais dans des lignes différentes.

Voici à quoi pourrait ressembler le non-pivot :

SELECT
  w.id,
  w.name,
  CASE x.pos WHEN 1 THEN w.position ELSE w.position2 END AS position,
  w.status
FROM tbl_workers AS w
  CROSS JOIN (SELECT 1 AS pos UNION ALL SELECT 2) AS x

Voici la requête entière, qui est essentiellement votre requête d'origine avec la requête ci-dessus remplaçant le tbl_workers tableau :

SELECT p.id, 
  p.position, 
  SUM(CASE w.Status WHEN 2 THEN 1 ELSE 0 END)  AS booked,
  SUM(CASE w.Status WHEN 3 THEN 1 ELSE 0 END)  AS placed
FROM tbl_positions AS p
  LEFT JOIN (
    SELECT
      w.id,
      w.name,
      CASE x.pos WHEN 1 THEN w.position ELSE w.position2 END AS position,
      w.status
    FROM tbl_workers AS w
      CROSS JOIN (SELECT 1 AS pos UNION ALL SELECT 2) AS x
  ) AS w 
  ON w.position=p.id
GROUP BY p.id, p.position

MISE À JOUR

Il s'agit d'un script modifié en fonction d'une demande supplémentaire dans les commentaires :

SELECT p.id, 
  p.position, 
  SUM(CASE w.Status WHEN 2 THEN 1 ELSE 0 END)  AS booked,
  SUM(CASE w.Status WHEN 3 THEN 1 ELSE 0 END)  AS placed
FROM tbl_positions AS p
  LEFT JOIN (
    SELECT
      w.id,
      w.name,
      CASE x.pos WHEN 1 THEN w.position ELSE w.position2 END AS position,
      CASE w.status
        WHEN 4 THEN CASE x.pos WHEN 1 THEN 3 ELSE 2 END
        ELSE w.status
      END AS status
    FROM tbl_workers AS w
      CROSS JOIN (SELECT 1 AS pos UNION ALL SELECT 2) AS x
  ) AS w 
  ON w.position=p.id
GROUP BY p.id, p.position

L'idée est de substituer le 4 statut dans la sous-sélection avec 3 ou 2 selon que nous devons actuellement tirer position ou position2 comme la position unifiée . La sélection externe continue d'utiliser la même logique qu'auparavant.