Если в операторе после ключевого слова указывается не одна, а 2 таблицы, то в результате выполнения запроса, в котором отсутствует предложение Where, каждая строка одной таблицы будет соединена с каждой строкой второй таблицы (декартовое произведение или полное соединение таблиц).
Сама по себе эта операция не имеет практического значения. Соединение таблиц соединение таблиц имеет смысл, если объединяют не все строки исходной таблицы, а только некоторые.
Пример: получить фамилии студентов, и для каждого студента название университетов, расположенных в городе, где живет студент.
Select surname, name,student.city
From student,univercity
Where student.city = university.city;
Или
Select surname, student.city, univer.city
From student join university
On student.city = university.city;
Outer – внешний, не является обязательным, оно не используется ни в каких операциях с данными и имеет смысл только в комбинации со спецификацией типа соединения(left, right, full).
Тип соединения называют левой если она стоит перед ключевым словом join, и правой, если стоит после него.
Left outer – тип соединения – левое внешнее(включает в себя все строки из левой таблицы и те строки из правой для которых выполняется условие. Для строк из левой таблицы, для которых не найдено соответствие в правой, столбцы извлекаемые из заносится значение null).
Right outer – тип соединения правое внешнее; правое соединение таблиц включает в себя все строки из правой таблицы и те из левой, для которых выполняется условие. Для строк из правой таблицы, для которых не найдено соответствие в левой, столбцы извлекаемые из левой таблицы заносятся значения null.
Full outer – тип соединения полное внешнее; это комбинация левого и правого соединений. В полное соединение включаются все строки из обеих таблиц. Для совпадающих строк поля заполняются реальными значениями, для несовпадающих – в соответствии с правилами левого и правого соединения.