Оператор LEFT JOIN в PostgreSQL отличается от других типов соединений тем, что возвращает все строки в левой таблице и только те строки в правой таблице, где условие соединения было удовлетворено. www.guru99.com
При применении этой команды запускается поиск совпадений в правой таблице для каждой строки из левой. aristov.tech Однако даже те строки из левой таблицы, к которым не будет найдено совпадения в правой, будут добавлены в результирующую выборку с подставленным значением NULL. aristov.tech
Другие типы соединений в PostgreSQL и их отличия:
- INNER JOIN (внутреннее соединение). aristov.tech postgrespro.ru В итоговой выборке остаются только записи, где ключи совпадают. aristov.tech
- LEFT OUTER JOIN. www.guru99.com postgrespro.ru Сначала выполняется внутреннее соединение (INNER JOIN). postgrespro.ru Затем в результат добавляются все строки из левой таблицы, которым не соответствуют никакие строки в правой, а вместо значений столбцов правой таблицы вставляются NULL. postgrespro.ru Таким образом, в результирующей таблице всегда будет минимум одна строка для каждой строки из левой таблицы. postgrespro.ru
- RIGHT OUTER JOIN. www.guru99.com postgrespro.ru Работает в обратном порядке: возвращает все строки таблицы с правой стороны и строки таблицы с левой стороны, где условие соединения выполнено. www.guru99.com При отсутствии совпадения в пару записывается NULL. aristov.tech