sql >> Database teknologi >  >> RDS >> Mysql

MySql fuld join (union) og bestilling på flere datokolonner

bare ved at bruge din databasestruktur og din forespørgsel, og da FULL OUTER JOIN ikke er tilgængelig i MySQL, tror jeg, at en løsning kunne være denne:

SELECT
    `newsid`,
    `text`,
    CASE
        WHEN `datetime` IS NULL THEN `pdate`
        ELSE `datetime`
    END as `datetime,
    `pcount`
(
SELECT *
FROM `news` as `n`
    LEFT OUTER JOIN (
                        SELECT count(pictureid) as `pcount`, datetime as `pdate`
                        FROM picture GROUP BY DATE(datetime)
                    ) as p ON DATE(n.datetime) = DATE(p.datetime) 
    UNION
SELECT * 
    FROM `news` as `n`
    RIGHT OUTER JOIN (
                        SELECT count(pictureid) as `pcount`, datetime as `pdate`
                        FROM picture GROUP BY DATE(datetime)
                    ) as p ON DATE(n.datetime) = DATE(p.datetime) 

)


  1. hvorfor varbinær i stedet for varchar

  2. MySQL-forespørgsel med alias, der ikke bruger et indeks

  3. Hvordan sender man kun click event (div), når man bruger jquery live funktion?

  4. SQL-serverydelse — test i skyen