INNER JOIN в SQL
В этом уроке вы узнаете, как получить данные из двух таблиц с помощью внутреннего соединения SQL.
INNER JOIN
— это наиболее распространенный тип объединения. Он возвращает только те строки, которые совпадают в обеих объединенных таблицах. Вот, как это выглядит на диаграмме Венна.
Давайте рассмотрим, как работает inner join
на примере.
У нас есть две таблицы сотрудников employees
и отделов departments
.
Таблица employees | Таблица departments |
+--------+--------------+------------+---------+ | emp_id | emp_name | hire_date | dept_id | +--------+--------------+------------+---------+ | 1 | Ethan Hunt | 2001-05-01 | 4 | | 2 | Tony Montana | 2002-07-15 | 1 | | 3 | Sarah Connor | 2005-10-18 | 5 | | 4 | Rick Deckard | 2007-01-03 | 3 | | 5 | Martin Blank | 2008-06-24 | NULL | +--------+--------------+------------+---------+ |
+---------+------------------+ | dept_id | dept_name | +---------+------------------+ | 1 | Administration | | 2 | Customer Service | | 3 | Finance | | 4 | Human Resources | | 5 | Sales | +---------+------------------+ |
Допустим, вам нужно получить ID (emp_id), имя (emp_name), дату приема на работу (hire_date) и название отдела (dept_name) только тех сотрудников, которые назначены в определенный отдел.
В реальной жизни некоторых сотрудники могут быть еще не назначены ни в какой из отделов. У нас такой тоже есть — Martin Blank под номером 5.
Вопрос заключается в том, как получить данные из обеих таблиц в одном SQL-запросе? Давайте выясним.
Если вы посмотрите на таблицу employees
, то заметите, что в ней есть столбец dept_id
, который содержит ID отдела, к которому приписан каждый сотрудник, т.е., говоря техническим языком, столбец dept_id
таблицы employees
является внешним ключом к таблице departments
. Мы будем использовать этот столбец как мост между этими двумя таблицами.
Вот пример запроса, который извлекает ID сотрудника, его имя, дату приема на работу и его отдел, соединяя таблицы employees
и departments
вместе с помощью общего столбца dept_id
. Сотрудники, которые не приписаны ни к какому отделу, при этом исключаются из результата.
SELECT t1.emp_id, t1.emp_name, t1.hire_date, t2.dept_name FROM employees AS t1 INNER JOIN departments AS t2 ON t1.dept_id = t2.dept_id ORDER BY emp_id;
Совет. При объединении таблиц, добавляйте к имени каждого столбца префикс с именем таблицы, к которой он принадлежит (например, employees.dept_id, departments.dept_id). Это позволят избежать путаницы и неоднозначности в случае, если у столбцов в разных таблицах одинаковое имя.
Примечание. Для экономии времени вместо ввода длинных имен таблиц в запросе можно использовать короткие имена таблиц — псевдонимы. Например, вы можете дать таблице
employees
псевдонимt1
с помощьюAS
и ссылаться на ее столбецemp_name
короче:t1.emp_name
вместоemployees.emp_name
.
После выполнения вышеуказанной команды вы получите набор результатов примерно следующего вида:
+--------+--------------+------------+-----------------+ | emp_id | emp_name | hire_date | dept_name | +--------+--------------+------------+-----------------+ | 1 | Ethan Hunt | 2001-05-01 | Human Resources | | 2 | Tony Montana | 2002-07-15 | Administration | | 3 | Sarah Connor | 2005-10-18 | Sales | | 4 | Rick Deckard | 2007-01-03 | Finance | +--------+--------------+------------+-----------------+
Как вы можете видеть, набор результатов содержит только тех сотрудников, для которых присутствует значение dept_id
, и оно существует в столбце dept_id
таблицы departments
.