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
Форумы портала PHP.SU » PHP » SQL и Архитектура БД » Поисковый запрос к базе mysql

Страниц (1): [1]
 

1. exlant - 05 Марта, 2015 - 22:14:45 - перейти к сообщению
Я хочу уточнить! В запросе типа
CODE (SQL):
скопировать код в буфер обмена
  1.  
  2. SELECT FROM WHERE colum1=colum1 AND colum2=colum2 OR colum3=colum3
  3.  


с начало выбираются все элементы, где colum1=colum1, затем из этого списка(список №1) выбираются все элементы , где colum2=colum2(список №2), а потом из списка №1 исключаются все элементы списка №2, и из него выбираются все элементы, где colum3=colum3 (список №3), а потом склеиваются список №2 и список №3, и уже отдаются в качестве ответа на sql запрос.

Я правильно понимаю??
2. Мелкий - 05 Марта, 2015 - 22:39:26 - перейти к сообщению
Никогда так не пишите. Укажите скобками явно, что вы хотите получить: (c1 and c2) or c3 или c1 and (c2 or c3)
Я понятий не имею, какой из вариантов выберет mysql.

План выполнения без индексов: смотрит всю таблицу построчно (порядок просмотра не регламентирован), если вся строка совпала под where - копирует в вывод.
С индексами - слишком много вариантов, вдобавок зависит от конкретных значений поиска и селективности индексов.
3. exlant - 05 Марта, 2015 - 23:12:05 - перейти к сообщению
Цитата:
Никогда так не пишите. Укажите скобками явно, что вы хотите получить: (c1 and c2) or c3 или c1 and (c2 or c3)

спасибо за уточнение, но оно сути к вопросу не имеет! Улыбка

Я так понял, что порядок условий которые идут после WHERE никакого значения не имеет! И если идет запрос с несколько десятками условий, то все строчки в базе данных будут проверяться по всем этим условиям!

 

Powered by ExBB FM 1.0 RC1