PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

Konvertieren von Oracle SQL Select in PostgreSQL select

Hier ist Ihre Abfrage, die mit ANSI-92 JOIN-Syntax umgeschrieben wurde:

  SELECT a.abx_apo_number,
         COUNT(ap1.process_mode) AS NUM_PLANNING,
         COUNT(ap2.process_mode) AS NUM_SETUP,
         COUNT(ap3.process_mode) AS NUM_OUTPUT
     FROM ABX a
LEFT JOIN USER_INSTANCE u ON u.abx_apo_number = a.abx_apo_number
LEFT JOIN ACTIVE_PROCESS ap1 ON ap1.process_instance_number = u.instance_number
                            AND ap1.process_mode = 'PLANNING'
LEFT JOIN ACTIVE_PROCESS ap2 ON ap2.process_instance_number = u.instance_number
                            AND ap2.process_mode = 'SETUP'
LEFT JOIN ACTIVE_PROCESS ap3 ON ap3.process_instance_number = u.instance_number
                            AND ap3.process_mode = 'OUTPUT'
 GROUP BY a.abx_apo_number

Der (+) ist eine Oracle-spezifische LEFT OUTER JOIN-Syntax. Um es zu entfernen, müsste jede USER_INSTANCE.instance_number müsste Werte für die Prozessmodi haben, die alle drei sind:PLANNING, SETUP und OUTPUT - lassen Sie einen weg, und die abx_apo_number würde nicht in der Ausgabe angezeigt.