Mysql
 sql >> Baza danych >  >> RDS >> Mysql

Jak wykonać pełne złącze zewnętrzne, aby połączyć dwie tabele w mysql?

Aby wykonać FULL OUTER JOIN możesz zrobić LEFT OUTER JOIN i UNION z RIGHT OUTER JOIN (pod warunkiem, że MySql nadal nie obsługuje FULL OUTER JOIN ):

select * from A as a
    left outer join B as b on a.col = b.col
union
select * from A as a
    right outer join B as b on a.col = b.col

Pamiętaj, że możesz użyć podzapytań dla A i B - które powinny działać z Twoimi zapytaniami. W Twoim przypadku:

select * from (SELECT * FROM t1) as a
    left outer join (SELECT * FROM t2) as b on a._tid = b._tid
union
select * from (SELECT * FROM t1) as a
    right outer join (SELECT * FROM t2) as b on a._tid = b._tid

Wynik równy (pod warunkiem, że nie popełniłem błędu podczas kopiowania i wklejania danych):

+------+-------+------------+----------+------+-------+------------+----------+
| _id  | _tid  | _dt        | _advance | _id  | _tid  | _dt        | _advartn |
+------+-------+------------+----------+------+-------+------------+----------+
|   17 | hjg   | 2012-04-18 |     2151 | NULL | NULL  | NULL       |     NULL |
|   22 | RKT01 | 2012-04-10 |     2098 | NULL | NULL  | NULL       |     NULL |
|   14 | RKT04 | 2012-04-18 |     1511 |    8 | RKT04 | 2012-04-20 |      150 |
|   16 | RKT09 | 2012-04-09 |      250 | NULL | NULL  | NULL       |     NULL |
|   15 | RKT10 | 2012-04-17 |     1313 | NULL | NULL  | NULL       |     NULL |
|    8 | RKT21 | 2012-04-03 |     1321 | NULL | NULL  | NULL       |     NULL |
|   19 | RKT31 | 2012-04-26 |     2512 | NULL | NULL  | NULL       |     NULL |
|   20 | RKT33 | 2012-04-10 |     2250 | NULL | NULL  | NULL       |     NULL |
|   25 | T01   | 2012-04-11 |     2500 | NULL | NULL  | NULL       |     NULL |
| NULL | NULL  | NULL       |     NULL |    9 | RKT02 | 2012-04-10 |     2500 |
+------+-------+------------+----------+------+-------+------------+----------+


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. przy użyciu MySql.Data.MySqlClient; nie działa

  2. ustawianie wartości flagi na podstawie rekordu istnieje w innej tabeli

  3. Jak alternatywnie sortować wyniki wielu zapytań?

  4. Doctrine Paginator wybiera całą tabelę (bardzo wolno)?

  5. Tworzenie tabeli z błędem przepełnienia arytmetycznego