|
|
|
| Один человек с друго форума говорит что внутренние соединения и перечисления таблиц в секции from это одно и тоже. По логике да, но ведь правильно же использовать INNER JOIN да?
Правда ли что из секции ON mysql переносит условие в секции WHERE? | |
|
|
|
|
|
|
|
для: garold
(13.06.2010 в 12:36)
| | перечисления таблиц в секции from не существует.
Существует операция "запятая", фактически являющаяся декартовым произведением (т.е. внутренним соединением с открытым условием ON) .
Так что использовать-то придется все равно одно и то же.
Другой вопрос, как правильно писать.
Поскольку результат один, а запись разная, значит это не столько вопрос логики,
сколько вопрос эстетики, стиля, вкуса.
Правда, даже в этом ключе, вопрос запросто может оказаться существенным.
Я, например, считаю, что запись JOIN ON выглядит более естественно, интуитивно более понятна, структурно более подчеркиввает смысловое наполнение запроса.
"Более" настолько, что применение формы запятая WHERE при отсутствии желания вытащить именно декартово произведение (при наличии явной ключевой пары и т.п. , особенно, если в WHERE живут и другие условия, окромя связи таблиц) воспринимаю, как издевательство над людьми, которые этот запрос будут читать.
А запросы в этом форуме я читаю очень многие - практически все.
А издеваетльство над собой любимым я воспринимаю болезненно, и могу даже сдачи дать . :)
>Правда ли что из секции ON mysql переносит условие в секции WHERE?
Что значит "переносит условие в секции WHERE"? | |
|
|
|
|
|
|
|
для: Trianon
(13.06.2010 в 14:33)
| | >Что значит "переносит условие в секции WHERE"?
Тоесть во время обработки запроса, оптимизатор (или парсер, не знаю как правильно) перенесет из условия ON в условие WHERE. Если бы использовался вариант с JOINом.
Или это чушь? | |
|
|
|
|
|
|
|
для: garold
(13.06.2010 в 14:54)
| | Во время обработки запроса, сервер этот запрос исполнит.
Никто никуда ничего носить не будет. | |
|
|
|