72 похожих чатов

Всем привет, достаточно простой вопрос (два), но не могу найти

ответ.
есть два запроса
select * from TABLE_A a left join TABLE_B b on a.pk = b.fk and( a.date_start ≤ b.date and a.date_end ≥ b.date)

select * from TABLE_A a left join TABLE_B b on a.pk = b.fk where a.date_start ≤ b.date and a.date_end ≥ b.date

Что это за мода пошла делать отбор после ON, он же будет не корректный.
И второе, как будет происходить выполнение

Когда ограничение в части ON находиться это относиться только к подключаемой таблицы.
а когда после WHERE это уже касается итоговой выборки. <— Правильное утверждение ?

Спасибо!

9 ответов

15 просмотров

> Что это за мода пошла делать отбор после ON, он же будет не корректный. Смотря какой результат нужен... Но второй запрос просто вводит в заблуждение (такое code review не пройдёт ;) ), это да. > Когда ограничение в части ON То это относится к данному JOIN, да.

Chern-Oleksander Автор вопроса
Yaroslav Schekin
> Что это за мода пошла делать отбор после ON, он ...

Спасибо Вам огромное, а чисто случайно не подскажите как правильно спросить у гугла, про этапы выполнения запроса оптимизатором? Хочу понимать что выполняется первым, что последующим. Например select user_id from tbl_1 join tbl2 on tbl_1.id=tbl_2.id where user_id =1 Limit 1 Cначало выполняется соединения таблиц, формируется +/- виртуальная таблица, потом к этой таблице приминяются условия where, после выполняется условия limit... Спасибо!

Chern Oleksander
Спасибо Вам огромное, а чисто случайно не подскажи...

Что-то вроде "logical sequence of sql query execution", например.

Chern-Oleksander Автор вопроса
Yaroslav Schekin
Что-то вроде "logical sequence of sql query execut...

Спасибо) И просто интересно не зачтите за флуд. А на кого вы учились? и сколько времени ушло чтобы так хорошо разбираться в БД ? и что больше читаете или курсы или сертификацию проходите или еще что-то?

Chern Oleksander
Спасибо) И просто интересно не зачтите за флуд. А ...

1. На программиста. 2. Не помню... несколько лет, кажется. 3. Книги и документацию. И это off topic, наверное. ;)

Это не эквивалентные запросы

Не совсем правильное утверждение, где-то близко к истине, но хромает формулировка

Chern Oleksander
Согласен

Условие в on использует значения полей ДО join Условие в Where - ПОСЛЕ. Все достаточно просто

Похожие вопросы

Обсуждают сегодня

Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Вот еще странный косяк, подскажите как бороться. Я git clone сделал себе всего embassy и примеры там запускаю. Всё хорошо. Но вот решил в cargo.toml зависимости не как в приме...
Lukutin R2AJP
5
Добрый вечер, Пока не совсем понимаю как наладить общение между телеграм ботом и ПО для работы с сим боксом. По самому боту так понял: - Нужен некий баланс, который можно поп...
Magic
6
Всем привет, нужна как никогда, нужна помощь с IO в загрузчике. Пишу в code16 после установки сегментных регистров, пишу вывод символа. Пробовал 2 варианта: # 1 mov $0x0E, %a...
Shadow Akira
14
Раз начали говорить про embassy, то присоединюсь со своими парой вопросов. 1) Есть ли сопоставимые аналоги для асинхронного кода в emdebbed? 2) Можно ли внутри задач embassy ...
NI_isx
6
сделал сайт, прикрутил в боте сайт, и виджет логина. как автоматически логинить пользователя в аккаунт(телеграм), при входе с бота?
Александра Чернивецкая
5
Объясните, пожалуйста, почему компилятор ругается на использование в условии неинициализированной переменной: int x; Task.Run(async () => { x = await somefunc(); }).Wait...
Александр
5
Всем привет. Ребята, подскажите, пожалуйста. у ботов есть ограничение на отправку сообщений - 30 сообщений в секунду, эти ограничения накладываются на все сообщения? или на со...
Artem Stormageddon
4
Коллеги, я тут для личных нужд пошел ставить MQTT сервер, пощупал mosquitto, но ужаснулся отсутствию такой банальности, как HTTP API для посмотреть список топиков. А тут что,...
Maksim Lapshin
14
Карта сайта