sql >> Database >  >> RDS >> Mysql

Hoe om te gaan met meerdere joins

Herschrijven als een UNION is eenvoudig, kopieer de bron en verwijder een van de OR ed voorwaarden in elk:

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;

Is er een index op pending_corrections.seenDate ?



  1. MySQL unieke id of gecombineerde id

  2. Ik krijg een pg-fout wanneer ik een controller probeer te vernietigen

  3. Docker Machine op Mac:Kan de gekoppelde volumes niet zien op de docker-host/docker-machine? Waar worden volumes fysiek opgeslagen?

  4. JSON_STORAGE_SIZE() - Vind de opslaggrootte van een JSON-document in MySQL