Список вопросов
Как зайти в Даркнет?!
25th January, 01:11
8
0
Как в tkinter из поля ввода Entry получить значение в одну переменную и обновить строку кнопкой, затем получить ещё одно введённое значение и затем сложить их. Ниже пример кода
21st July, 19:00
898
0
Программа, которая создает фейковые сервера в поиске игровых серверов CS 1.6 Steam
21st March, 17:43
951
0
Очень долго работает Update запрос Oracle
27th January, 09:58
916
0
не могу запустить сервер на tomcat HTTP Status 404 – Not Found
21st January, 18:02
907
0
Где можно найти фрилансера для выполнения поступающих задач, на постоянной основе?
2nd December, 09:48
941
0
Разработка мобильной кроссплатформенной военной игры
16th July, 17:57
1725
0
период по дням
25th October, 10:44
3957
0
Пишу скрипты для BAS только на запросах
16th September, 02:42
3722
0
Некорректный скрипт для закрытия блока
14th April, 18:33
4614
0
прокидывать exception в блоках try-catch JAVA
11th March, 21:11
4382
0
Помогите пожалуйста решить задачи
24th November, 23:53
6087
0
Не понимаю почему не открывается детальное описание продукта
11th November, 11:51
4352
0
Нужно решить задачу по программированию на массивы
27th October, 18:01
4398
0
Метода Крамера С++
23rd October, 11:55
4309
0
помогите решить задачу на C++
22nd October, 17:31
4002
0
Помогите решить задачу на python с codeforces
22nd October, 11:11
4492
0
Python с нуля: полное руководство для начинающих
18th June, 13:58
2599
0
Медленная сортировка по дате в Mysql
Просмотров: 368
 
Ответов: 3
имеется медленный запрос (для 30к постов и 30к юзеров выполняется за 0.2с):
SELECT *
FROM `posts`
JOIN `users` ON ( `posts`.`user_id` = `users`.`id` )
GROUP BY `posts`.`id`
ORDER BY `posts`.`date` DESC
LIMIT 10
описывать стуктуру таблиц не буду полностью, т.к. полей много а на суть вопроса это не влияет, опишу основное — date типа datetime, ID типа int
праймери индексы на posts.id и users.id + индекс на posts.user_id
при таком раскладе запрос выполняется за 0.2с
если поставить индекс на date запрос выполняется все равно за 0.2с
если поставить сортировку по posts.id (что в принципе эквивалентно date), запрос выполняется за 0.001с
если убрать JOIN users запрос выполняется за 0.001с
explain:
без индекса на posts.date, время 0.2с
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
|---|---|---|---|---|---|---|---|---|---|
| 1 | SIMPLE | posts | index | user_id | PRIMARY | 4 | NULL | 1000 | Using where; Using temporary; Using filesort |
| 1 | SIMPLE | users | eq_ref | PRIMARY | PRIMARY | 3 | db_site.posts.user_id | 1 | Using where |
с индексом на posts.date, время 0.2с
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
|---|---|---|---|---|---|---|---|---|---|
| 1 | SIMPLE | posts | index | user_id | date | 8 | NULL | 1000 | Using where; Using temporary |
| 1 | SIMPLE | users | eq_ref | PRIMARY | PRIMARY | 3 | db_site.posts.user_id | 1 | Using where |
без сортировки по posts.date, время 0.001с
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
|---|---|---|---|---|---|---|---|---|---|
| 1 | SIMPLE | posts | index | user_id | PRIMARY | 4 | NULL | 1000 | Using where |
| 1 | SIMPLE | users | eq_ref | PRIMARY | PRIMARY | 3 | db_site.posts.user_id | 1 | Using where |
а теперь внимание, вопрос — как сделать сортировку по дате быстрой? и что я делаю не так…
Я бы на Вашем месте изменил бы структуру страницы posts. На сколько я понимаю табличка users Вам нужна для отображения имени автора поста, я бы добавил в табличку posts нужные поля ( имя автора, может рейтинг поста, нужные в общем), и не соединял бы остальные таблички, но в таким случае нужно при обновлении других таблиц смотреть и посты. Работать будет в разы быстрей, но внимания нужно будет тоже больше уделить изменениям.
Чтобы ответить на вопрос вам нужно войти в систему или зарегистрироваться