Фильтрация объединений исключительно с использованием ГДЕ может быть крайне неэффективной в некоторых распространенных сценариях. Например:
SELECT * FROM people p, companies c WHERE p.companyID = c.id AND p.firstName = 'Daniel'
Большинство баз данных выполнят этот запрос буквально, сначала беря декартово произведение таблиц людей и компаний, а затем фильтруя по тем, которые имеют совпадающие поля companyID и id. В то время как полностью неограниченный продукт не существует нигде, кроме как в памяти и только на мгновение, его расчет занимает некоторое время.
Лучший подход - группировать ограничения с соединениями, где это уместно. Это не только субъективно легче читать, но и намного эффективнее. Thusly:
SELECT * FROM people p JOIN companies c ON p.companyID = c.id
WHERE p.firstName = 'Daniel'
Это немного дольше, но база данных может посмотреть на предложение ON и использовать его для непосредственного вычисления полностью ограниченного JOIN, вместо того, чтобы начинать со всего и затем ограничивать. Это быстрее для вычисления (особенно с большими наборами данных и / или объединениями из нескольких таблиц) и требует меньше памяти.
Я изменяю каждый запрос, который использует синтаксис "запятая JOIN". На мой взгляд, единственной целью его существования является лаконичность. Учитывая влияние на производительность, я не думаю, что это веская причина.