sql >> Database >  >> RDS >> Oracle

Oracle SQL - Query om waarden uit meerdere tabellen te berekenen

U kunt meerdere algemene tabeluitdrukkingen gebruiken, elk afzonderlijk berekenen en samenvoegen, zodat u begrijpt wat er aan de hand is.

SQL Fiddle

Zoekopdracht :

WITH aud(manager_email,Total_audits) AS
  (SELECT manager_email,
    SUM (
    CASE
      WHEN audit_eligible = 'Y'
      THEN audits_required
    END )
  FROM REQUIRED_AUDITS
  GROUP BY manager_email
  ),  --Total_audits

  scores(manager_email,Audits_Performed) AS
  (SELECT manager_email,
    COUNT ( ID )
  FROM SCORE_ENTRY s
  GROUP BY manager_email
  )  --Audits_Performed

SELECT h.manager_email manager,
  a.Total_audits,
  s.Audits_Performed,
  100 * s.Audits_Performed / a.Total_audits percentage_complete
FROM HR h
LEFT OUTER JOIN aud a
ON h.manager_email = a.manager_email
LEFT OUTER JOIN scores s
ON h.manager_email = s.manager_email
ORDER BY 2 DESC NULLS LAST 

Resultaten :

|       MANAGER | TOTAL_AUDITS | AUDITS_PERFORMED | PERCENTAGE_COMPLETE |
|---------------|--------------|------------------|---------------------|
|  [email protected] |           10 |                1 |                  10 |
| [email protected] |            9 |                2 |   22.22222222222222 |
| [email protected] |       (null) |           (null) |              (null) |
|  [email protected] |       (null) |           (null) |              (null) |
| [email protected] |       (null) |           (null) |              (null) |


  1. Vraag en aanbod matchen Uitdaging

  2. Dynamische SQL-query uitvoeren in Oracle

  3. SQL Inner join op geselecteerde instructies

  4. Is het mogelijk om sql%rowcount te gebruiken voor SELECT?