SQLRU.net
Разработка приложений баз данных

Начало » SQL.RU » Вопрос-Ответ » Помощь экспертов так сказать (Обучение )
Помощь экспертов так сказать [сообщение #4569] Mon, 04 March 2024 15:15 Переход к следующему сообщению
JustAlex в настоящее время не в онлайне  JustAlex
Сообщений: 5
Зарегистрирован: March 2024
Junior Member
Доброго времени суток, форумчане!

На данный момент нахожусь в процессе изучения SQL посредством платформы LearnDB.ru, застрял уже на 4-й задаче 3-го курса (кому не лень - лучше зайти и посмотреть, это бесплатно, вроде как можно перескакивать на курсы, не проходя предыдующие). Собственно, прошу помощи у уважаемых продвинутых пользователей.

Условия задачи следующие:

"Помоги сотрудникам найти повышение в должности, либо перейти на ту же должность, но в другой магазин.
Для каждого сотрудника получи информацию о должностях либо магазина, в котором работает сотрудник, либо должностях с таким же индентификатором должности в другом магазине.

Выведи следующие столбцы:
last_name - фамилия сотрудника;
first_name - имя сотрудника;
store_id_employee - идентификатор магазина сотрудника;
store_id_rank - идентификатор магазина должности;
rank_id - идентификатор должности в магазине;
rank_name - название должности.

Отсортируй результат по
фамилии;
имени;
идентификатору магазина должности;
идентификатору должности".

Таблицы, которые нужно использовать: employee (далее - e, прил. 1) и rank (далее - r, прил. 2).
Схема данных также прилагается (прил. 3).

Вот эталонное решение, которое предлагает сайт:

SELECT e.last_name,
      e.first_name,
      e.store_id as store_id_employee,
      r.store_id as store_id_rank,
      r.rank_id,
      r.name as rank_name
 FROM employee e
 JOIN rank r
   ON r.store_id = e.store_id
   OR (r.rank_id = e.rank_id AND r.store_id != e.store_id)
ORDER BY e.last_name, e.first_name, r.store_id, r.rank_id

Вот мое решение, которое сработало (как - я не понимаю, нашел, по сути, методом "тыка"):

SELECT e.last_name,
      e.first_name,
      e.store_id AS store_id_employee,
      r.store_id AS store_id_rank,
      r.rank_id,
      r.name AS rank_name
 FROM employee e
 JOIN rank r
   ON r.rank_id = e.rank_id
  AND r.store_id != e.store_id
   OR r.store_id = e.store_id
ORDER BY e.last_name, e.first_name, r.store_id, r.rank_id

Я не понимаю, почему оператор ON, - а точнее то, что идет после него, - выглядит именно так, как оно выглядит в решениях.

Вопрос 1
Как видно на схеме данных (прил. 3), таблице r присвоено два ключа: store_id и rank_id. Соответственно, чтобы name (название должности) из таблицы r привязалось к конкретному employee_id (идентификатор сотрудника) из таблицы e, нужно, чтобы store_id и rank_id из таблицы r привязались к store_id и rank_id из таблицы e, то есть решение, по моей логике, в любом случае должно содержать следующее в качестве не достаточного, но необходимого условия:

 FROM employee e
 JOIN rank r
   ON r.store_id = e.store_id
   AND r.rank_id = e.rank_id
   ...

Однако, как мы видим в эталонном решении, этого нет, вместо этого:

FROM employee e
 JOIN rank r
   ON r.store_id = e.store_id
   OR (r.rank_id = e.rank_id AND r.store_id != e.store_id)

То есть в эталонном решении, как я понимаю, в обязательном порядке из r к e присоединяется только store_id. Как в таком случае name (название должности) из r будет верно для employee_id из e, если для определения name из r используются два ключа store_id и rank_id, а не только store_id?


Вопрос 2
Почему такой вариант решения работает:

SELECT e.last_name,
      e.first_name,
      e.store_id AS store_id_employee,
      r.store_id AS store_id_rank,
      r.rank_id,
      r.name AS rank_name
 FROM employee e
 JOIN rank r
   ON r.rank_id = e.rank_id
  AND r.store_id != e.store_id
   OR r.store_id = e.store_id
ORDER BY e.last_name, e.first_name, r.store_id, r.rank_id

а такой нет (оставил только отличающуюся часть):

   ON r.rank_id = e.rank_id
  AND r.store_id = e.store_id
   OR r.store_id != e.store_id

Чем они отличаются? Какая разница в каком порядке стоит то, что между OR? "Купи арбуз или дыню" и "купи дыню или арбуз" это одно и то же - что я не понимаю?

Прошу прощения за много букв. Был бы очень благодарен за помощь.
Re: Помощь экспертов так сказать [сообщение #4570 является ответом на сообщение #4569] Mon, 04 March 2024 17:35 Переход к предыдущему сообщениюПереход к следующему сообщению
BlackEric в настоящее время не в онлайне  BlackEric
Сообщений: 369
Зарегистрирован: June 2022
Senior Member
r.store_id = e.store_id
OR r.store_id != e.store_id

Это условие вообще лишнее. Там будет true вне зависимости от того совпадают store_id или нет

Re: Помощь экспертов так сказать [сообщение #4571 является ответом на сообщение #4569] Tue, 05 March 2024 00:26 Переход к предыдущему сообщениюПереход к следующему сообщению
hvlad в настоящее время в онлайне  hvlad
Сообщений: 364
Зарегистрирован: August 2022
Senior Member
RTFM логические операции, приоритеты операций

PS выражения
r.store_id = e.store_id
   OR (r.rank_id = e.rank_id AND r.store_id != e.store_id)
и
r.rank_id = e.rank_id
  AND r.store_id != e.store_id
   OR r.store_id = e.store_id
эквивалентны

А вот это
 r.rank_id = e.rank_id
  AND r.store_id = e.store_id
   OR r.store_id != e.store_id
уже совсем другое выражение.
Re: Помощь экспертов так сказать [сообщение #4572 является ответом на сообщение #4571] Tue, 05 March 2024 13:05 Переход к предыдущему сообщениюПереход к следующему сообщению
JustAlex в настоящее время не в онлайне  JustAlex
Сообщений: 5
Зарегистрирован: March 2024
Junior Member
А почему оно совсем другое?
Re: Помощь экспертов так сказать [сообщение #4573 является ответом на сообщение #4572] Tue, 05 March 2024 13:52 Переход к предыдущему сообщениюПереход к следующему сообщению
hvlad в настоящее время в онлайне  hvlad
Сообщений: 364
Зарегистрирован: August 2022
Senior Member
JustAlex писал(а) Tue, 05 March 2024 12:05
А почему оно совсем другое?
По-построению.

Могу только повторить о необходимости знать хоть что-то о предмете.
В частности - о приоритете логических операций.
Re: Помощь экспертов так сказать [сообщение #4575 является ответом на сообщение #4573] Wed, 06 March 2024 11:09 Переход к предыдущему сообщениюПереход к следующему сообщению
JustAlex в настоящее время не в онлайне  JustAlex
Сообщений: 5
Зарегистрирован: March 2024
Junior Member
Так прочитал и все равно не понял. Приоритет следуюдий - 1) NOT, 2) AND и 3) OR.
Соответственно, как я понимаю, в этом выражении

r.rank_id = e.rank_id
 AND r.store_id != e.store_id
  OR r.store_id = e.store_id

будут выдаваться результаты, в которых для e из r совпадает rank_id и store_id или совпадает rank_id и не совпадает store_id.

Если это верно, то почему в этом выражении

r.rank_id = e.rank_id
 AND r.store_id = e.store_id
  OR r.store_id != e.store_id

не будет того же самого, если разница только в том, что то, что между OR, поменяли местами?

Условно, как я писал выше, выражение "купи бутерброд с колбасой или сыром" и выражение "купи бутерброд с сыром или колбасой" равнозначны. Почему здесь так не работает?
 

[Обновления: Wed, 06 March 2024 11:11]

Известить модератора

Re: Помощь экспертов так сказать [сообщение #4576 является ответом на сообщение #4575] Wed, 06 March 2024 11:44 Переход к предыдущему сообщениюПереход к следующему сообщению
МП в настоящее время не в онлайне  МП
Сообщений: 889
Зарегистрирован: August 2022
Географическое положение: бурятский тун...
Senior Member
расставь приоритеты:
(купи бутерброд с сыром) или колбасу
Re: Помощь экспертов так сказать [сообщение #4577 является ответом на сообщение #4575] Wed, 06 March 2024 11:49 Переход к предыдущему сообщениюПереход к следующему сообщению
hvlad в настоящее время в онлайне  hvlad
Сообщений: 364
Зарегистрирован: August 2022
Senior Member
JustAlex
Так прочитал и все равно не понял. Приоритет следуюдий - 1) NOT, 2) AND и 3) OR.
Теперь попробуй расставить скобки в соответствии с приоритетом.
Или просто пронумеруй операции в порядке их выполнения.

В таком виде будет чуть проще:
r.rank_id = e.rank_id AND r.store_id != e.store_id OR r.store_id = e.store_id

r.rank_id = e.rank_id AND r.store_id = e.store_id  OR r.store_id != e.store_id
Re: Помощь экспертов так сказать [сообщение #4578 является ответом на сообщение #4577] Wed, 06 March 2024 14:01 Переход к предыдущему сообщениюПереход к следующему сообщению
JustAlex в настоящее время не в онлайне  JustAlex
Сообщений: 5
Зарегистрирован: March 2024
Junior Member
Для первого:
r.rank_id = e.rank_id AND r.store_id != e.store_id OR r.store_id = e.store_id

будет выглядеть следующим образом:
1) r.rank_id = e.rank_id + r.store_id != e.store_id
2) r.rank_id = e.rank_id + r.store_id = e.store_id

Если со скобками, то можно, наверное, так представить:
(r.rank_id = e.rank_id AND r.store_id != e.store_id)
OR (r.rank_id = e.rank_id AND r.store_id = e.store_id

Для второго:
r.rank_id = e.rank_id AND r.store_id = e.store_id  OR r.store_id != e.store_id

будет выглядеть следующим образом:
1) r.rank_id = e.rank_id + r.store_id = e.store_id
2) r.rank_id = e.rank_id + r.store_id != e.store_id

Я так это вижу. Но раз Вы говорите, что это неправильно, я верю. Пытаюсь лишь понять, почему это неправильно и какой порядок.

[Обновления: Wed, 06 March 2024 14:03]

Известить модератора

Re: Помощь экспертов так сказать [сообщение #4580 является ответом на сообщение #4578] Wed, 06 March 2024 17:11 Переход к предыдущему сообщениюПереход к следующему сообщению
hvlad в настоящее время в онлайне  hvlad
Сообщений: 364
Зарегистрирован: August 2022
Senior Member
JustAlex
Для первого:
r.rank_id = e.rank_id AND r.store_id != e.store_id OR r.store_id = e.store_id
...
Если со скобками, то можно, наверное, так представить:
(r.rank_id = e.rank_id AND r.store_id != e.store_id)
OR (r.rank_id = e.rank_id AND r.store_id = e.store_id
Нет, так нельзя.

Ок, ещё одна попытка.
Расставь скобки в таком выражении:
x * y + z
А теперь в таком:
a AND b OR c
И, напоследок, в таком:
a AND b OR NOT b
PS Я не понимаю, как можно не знать насколько элементарных вещей...
Re: Помощь экспертов так сказать [сообщение #4581 является ответом на сообщение #4580] Wed, 06 March 2024 17:39 Переход к предыдущему сообщению
JustAlex в настоящее время не в онлайне  JustAlex
Сообщений: 5
Зарегистрирован: March 2024
Junior Member
1) (x * y) + z

2) (a AND b) OR c

3) Честно говоря, я не знал, что можно совмещать операторы таким образом  - OR NOT, но полагаю, что a AND b OR NOT b можно представить так: (NOT b) OR (a AND b)

PS Такое бывает, когда занимаешься чем-то всего четыре дня) Благодарю Вас за помощь
Предыдущая тема: Что делать?
Следующая тема: Какой запрос выводит таблицы с большими индексами?
Переход к форуму:
  


Текущее время: Mon Dec 30 20:10:53 GMT+3 2024

Общее время, затраченное на создание страницы: 0.00917 секунд