sql >> Base de Datos >  >> RDS >> Mysql

¿Cómo puedo hacer una UNIÓN EXTERNA COMPLETA en MySQL?

No tienes uniones completas en MySQL, pero puede emularlos .

Para un código ejemplo transcrito de esta pregunta de desbordamiento de pila tienes:

Con dos tablas t1, t2:

SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
UNION
SELECT * FROM t1
RIGHT JOIN t2 ON t1.id = t2.id

La consulta anterior funciona para casos especiales en los que una combinación externa completa la operación no produciría filas duplicadas. La consulta anterior depende de UNION establecer operador para eliminar filas duplicadas introducidas por el patrón de consulta. Podemos evitar la introducción de filas duplicadas usando un anti-join patrón para la segunda consulta y, a continuación, utilice un operador de conjuntos UNION ALL para combinar los dos conjuntos. En el caso más general, donde una combinación externa completa devolvería filas duplicadas, podemos hacer esto:

SELECT * FROM t1
LEFT JOIN t2 ON t1.id = t2.id
UNION ALL
SELECT * FROM t1
RIGHT JOIN t2 ON t1.id = t2.id
WHERE t1.id IS NULL