1 В избранное 0 Ответвления 0

OSCHINA-MIRROR/xuthus5-Database-SQL-Actual-Combat

Клонировать/Скачать
56.获取所有员工的emp_no.md 2.5 КБ
Копировать Редактировать Web IDE Исходные данные Просмотреть построчно История
Отправлено 10.03.2025 00:53 c66e7df

Получение всех номеров сотрудников emp_no

Описание задачи

Получите все номера сотрудников emp_no, номера департаментов dept_no и соответствующие им типы бонусов btype и даты получения received. Сотрудники, которым не были назначены конкретные бонусы, не должны отображаться.

CREATE TABLE `dept_emp` ( `emp_no` int(11) NOT NULL,
`dept_no` char(4) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_no`));
CREATE TABLE `dept_manager` (
`dept_no` char(4) NOT NULL,
`emp_no` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`dept_no`));
CREATE TABLE `employees` (
`emp_no` int(11) NOT NULL,
`birth_date` date NOT NULL,
`first_name` varchar(14) NOT NULL,
`last_name` varchar(16) NOT NULL,
`gender` char(1) NOT NULL,
`hire_date` date NOT NULL,
PRIMARY KEY (`emp_no`));
CREATE TABLE `salaries` (
`emp_no` int(11) NOT NULL,
`salary` int(11) NOT NULL,
`from_date` date NOT NULL,
`to_date` date NOT NULL,
PRIMARY KEY (`emp_no`,`from_date`));
-- Отсутствует таблица в официальном задании
CREATE TABLE `emp_bonus` (
`emp_no` int not null,
`received` datetime not null,
`btype` smallint not null);

Ответ

SELECT t1.emp_no, dept_no, btype, received FROM (SELECT e.emp_no, dept_no FROM employees e JOIN dept_emp de ON e.emp_no = de.emp_no) t1 LEFT JOIN emp_bonus eb ON t1.emp_no = eb.emp_no

Объяснение решения

Задание составлено с множеством ошибок:

  1. Получите все номера сотрудников emp_no и номера департаментов dept_no.
SELECT e.emp_no, dept_no FROM employees e JOIN dept_emp de ON e.emp_no = de.emp_no
  1. Требуется, чтобы поля btype и received отображались только для сотрудников, которым были назначены конкретные бонусы. Для остальных сотрудников эти поля не должны отображаться, что указывает на необходимость использования оператора объединения данных (JOIN).### Примечание Исправлена ошибка в названии столбца received, который был записан как recevied.

Опубликовать ( 0 )

Вы можете оставить комментарий после Вход в систему

1
https://api.gitlife.ru/oschina-mirror/xuthus5-Database-SQL-Actual-Combat.git
git@api.gitlife.ru:oschina-mirror/xuthus5-Database-SQL-Actual-Combat.git
oschina-mirror
xuthus5-Database-SQL-Actual-Combat
xuthus5-Database-SQL-Actual-Combat
master