Модераторы: skyboy
  

Поиск:

Ответ в темуСоздание новой темы Создание опроса
> WHERE id IN (массив) ИЛИ WHERE id = элемент массив, какая выбора быстрее? 
:(
    Опции темы
Wowa
  Дата 7.3.2005, 16:35 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
Group Icon


Профиль
Группа: Админ
Сообщений: 15017
Регистрация: 14.9.2000
Где: Винград

Репутация: нет
Всего: 290



Исходные данные: В базе около 20 000строк
Массив: до 20 000 элементов
Какая выбора будет быстрее и стоит может не выбирать все строки сразу, что память не сожрали?

Это одиночная:
Код

SELECT * FROM table WHERE id IN (массив)



Или эта, которая выполнятся ровно столько раз, сколько элементов в массив
Код

while (массив) {
SELECT * FROM table WHERE id = элемент массива
}

PM WWW   Вверх
Mal Hack
Дата 7.3.2005, 16:38 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Мудрый...
****


Профиль
Группа: Участник Клуба
Сообщений: 9926
Регистрация: 15.2.2004

Репутация: 8
Всего: 261



Лучше, конечно, 1 запрос.
PM ICQ   Вверх
Wowa
Дата 7.3.2005, 16:43 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
Group Icon


Профиль
Группа: Админ
Сообщений: 15017
Регистрация: 14.9.2000
Где: Винград

Репутация: нет
Всего: 290



Цитата(Mal @ 7.3.2005, 14:38)
Лучше, конечно, 1 запрос.

Но при наличии 20 000 элементов массива у меня даже строка запроса будет очень длинной.
PM WWW   Вверх
Mal Hack
Дата 7.3.2005, 17:21 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Мудрый...
****


Профиль
Группа: Участник Клуба
Сообщений: 9926
Регистрация: 15.2.2004

Репутация: 8
Всего: 261



ты думаешь будет лучше посылать 20 000 запросов?
Да, возможно в таком случае может быть и можно выиграть с 10 запросами по 2000 в каждом.
Но это уже от многих факторов зависит.
Когда-то я поднимал тему по этому вопросу... Эх, че-то найти не могу...
PM ICQ   Вверх
Secandr
Дата 7.3.2005, 17:39 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Связист
****


Профиль
Группа: Экс. модератор
Сообщений: 4043
Регистрация: 3.8.2003
Где: Russia, Volgograd

Репутация: 6
Всего: 39



А что тут спорить. Нужно устроить полевые испытания smile


--------------------
Мышки плакали, кололись, но продолжали жрать кактусы (с) cisco
PM ICQ AOL   Вверх
Secandr
Дата 7.3.2005, 19:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Связист
****


Профиль
Группа: Экс. модератор
Сообщений: 4043
Регистрация: 3.8.2003
Где: Russia, Volgograd

Репутация: 6
Всего: 39



А вот такой вопрос: Если у нас есть массив 2,3,4,5,6,7,8,9,55,56,57,58,59,60 то может быть есть смысл сделать немного интелекта программе, пусть она заменить
Код

WHERE id IN (2,3,4,5,6,7,8,9,55,56,57,58,59,60)

На
Код

WHERE (id >2 and id <9 ) or (id>55 and id < 60)



--------------------
Мышки плакали, кололись, но продолжали жрать кактусы (с) cisco
PM ICQ AOL   Вверх
Ser9a
Дата 8.3.2005, 22:41 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Шустрый
*


Профиль
Группа: Участник
Сообщений: 70
Регистрация: 7.3.2005

Репутация: нет
Всего: нет



врят ли заранее известно какие именно данные в массиве, так что написать

[quote] WHERE (id >2 and id <9 ) or (id>55 and id < 60) врят ли выйдет.


20000 элементов не так уж и много памяти сожрут.



PM MAIL ICQ   Вверх
sergejzr
Дата 8.3.2005, 23:37 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 1
Всего: 360



ИМХО самое быстрое будет запрос типа:
Код

SELECT * FROM TABLEX WHERE id=mas[0];
UNION
SELECT * FROM TABLEX WHERE id=mas[1];
UNION
SELECT * FROM TABLEX WHERE id=mas[2];


Этот запрос создать на ПХП например и за раз отправить.
Добавлено @ 23:39
Например так:
Код
SQL= "SELECT * FROM TABLEX WHERE id=".join(";UNION SELECT * FROM TABLEX WHERE id=", massiv).";";

Добавлено @ 23:45
Если id проиндексирован конечно smile
Добавлено @ 23:45
Кстати, строку можно разбить на несколько, если у Базы проблемы с её длинной smile


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
Wowa
Дата 9.3.2005, 00:06 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Эксперт
Group Icon


Профиль
Группа: Админ
Сообщений: 15017
Регистрация: 14.9.2000
Где: Винград

Репутация: нет
Всего: 290



Цитата(sergej @ 8.3.2005, 21:37)
Кстати, строку можно разбить на несколько, если у Базы проблемы с её длинной

т.е. как разбить? несколько запросов отправить? Я имел ввиду длину запроса.
PM WWW   Вверх
sergejzr
Дата 9.3.2005, 00:10 (ссылка) | (нет голосов) Загрузка ... Загрузка ... Быстрая цитата Цитата


Un salsero
Group Icon


Профиль
Группа: Админ
Сообщений: 13285
Регистрация: 10.2.2004
Где: Германия г .Ганновер

Репутация: 1
Всего: 360



Если в массиве 20 000 елементов, разбмваешь его на 200 по 100 и в цикле отправляешь запрос за запросом (получается скомбинированный вариант). Это по скорости будет намного шустрее чем IN и длинна запроса будет ограничена.

А если элементов <100 по моему даже делить не надо ничего smile


--------------------
PM WWW IM ICQ Skype GTalk Jabber AOL YIM MSN   Вверх
  
Ответ в темуСоздание новой темы Создание опроса
1 Пользователей читают эту тему (1 Гостей и 0 Скрытых Пользователей)
0 Пользователей:
« Предыдущая тема | MySQL | Следующая тема »


 




[ Время генерации скрипта: 0.0921 ]   [ Использовано запросов: 21 ]   [ GZIP включён ]


Реклама на сайте     Информационное спонсорство

 
По вопросам размещения рекламы пишите на vladimir(sobaka)vingrad.ru
Отказ от ответственности     Powered by Invision Power Board(R) 1.3 © 2003  IPS, Inc.