sql >> Databasteknik >  >> RDS >> Mysql

Hur man hanterar flera sammanfogningar

Omskrivning som en UNION är enkelt, kopiera källan och ta bort en av OR ed villkor i varje:

SELECT 
   pending_corrections.corrected_plate , pending_corrections.seenDate
FROM
    (pending_corrections
    INNER JOIN cameras ON pending_corrections.camerauid = cameras.camera_id)
        INNER JOIN
    vehicle_vrn ON (pending_corrections.corrected_plate = vehicle_vrn.vrn500)
        INNER JOIN
    vehicle_ownership ON vehicle_vrn.fk_sysno = vehicle_ownership.fk_sysno
WHERE
    pending_corrections.seenDate >= '2015-01-01 00:00:00'
        AND pending_corrections.seenDate <= '2015-01-31 23:59:59'

union 

SELECT 
   pending_corrections.corrected_plate , pending_corrections.seenDate
FROM
    (pending_corrections
    INNER JOIN cameras ON pending_corrections.camerauid = cameras.camera_id)
        INNER JOIN
    vehicle_vrn ON pending_corrections.corrected_plate = vehicle_vrn.vrnno)
        INNER JOIN
    vehicle_ownership ON vehicle_vrn.fk_sysno = vehicle_ownership.fk_sysno
WHERE
    pending_corrections.seenDate >= '2015-01-01 00:00:00'
        AND pending_corrections.seenDate <= '2015-01-31 23:59:59'

ORDER BY 1,2;

Finns det ett index på pending_corrections.seenDate ?



  1. Infoga uttalande med där klausul inte körs på nodejs mysql

  2. ORA-00910:specificerad längd för lång för dess datatyp

  3. Hur söker jag efter namn som börjar på A i MySQL?

  4. Tvinga Oracle att returnera de N-ÖVNA raderna med SKIP LÅST