Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757
Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770 Форумы портала PHP.SU :: Версия для печати :: Поисковый запрос к базе mysql
SELECTFROMWHERE colum1=colum1 AND colum2=colum2 OR colum3=colum3
с начало выбираются все элементы, где colum1=colum1, затем из этого списка(список №1) выбираются все элементы , где colum2=colum2(список №2), а потом из списка №1 исключаются все элементы списка №2, и из него выбираются все элементы, где colum3=colum3 (список №3), а потом склеиваются список №2 и список №3, и уже отдаются в качестве ответа на sql запрос.
Никогда так не пишите. Укажите скобками явно, что вы хотите получить: (c1 and c2) or c3 или c1 and (c2 or c3)
Я понятий не имею, какой из вариантов выберет mysql.
План выполнения без индексов: смотрит всю таблицу построчно (порядок просмотра не регламентирован), если вся строка совпала под where - копирует в вывод.
С индексами - слишком много вариантов, вдобавок зависит от конкретных значений поиска и селективности индексов.
Никогда так не пишите. Укажите скобками явно, что вы хотите получить: (c1 and c2) or c3 или c1 and (c2 or c3)
спасибо за уточнение, но оно сути к вопросу не имеет!
Я так понял, что порядок условий которые идут после WHERE никакого значения не имеет! И если идет запрос с несколько десятками условий, то все строчки в базе данных будут проверяться по всем этим условиям!