powered by simpleCommunicator - 2.0.60     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / 2 индекс не работает.
1 сообщений из 1, страница 1 из 1
2 индекс не работает.
    #33953308
4321
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
автор
Код: plaintext
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
16.
17.
18.
19.
20.
21.
22.
23.
Индекс

CREATE INDEX idx_top_views
  ON album_photos
  USING btree
  (views, sex) WHERE participate_top;


Запрос

select photo_id from album_photos
where 
	participate_top and sex=1
order by views DESC
LIMIT 1


Explain запроса

Limit  (cost=1.47..1.48 rows=1 width=8)
  ->  Sort  (cost=1.47..1.48 rows=1 width=8)
        Sort Key: views
        ->  Seq Scan on album_photos  (cost=0.00..1.46 rows=1 width=8)
              Filter: (participate_top AND (sex = 1))

проблема даже не в Postgre, а в непонимании отбора по сложному индексу. переставьте views в конец. а лучше
Код: plaintext
1.
2.
3.
CREATE INDEX idx_top_sex_views
  ON album_photos
  USING btree
  ( sex, (-views)) WHERE participate_top;

т.к. Постгрес не поддерживает DESC в индексах, но
views int4,
что дает вам возможность задавать запрос в виде
Код: plaintext
1.
2.
3.
4.
select photo_id from album_photos
where 
	participate_top and sex= 1 
order by (-views) --DESC
LIMIT  1 
...
Рейтинг: 0 / 0
1 сообщений из 1, страница 1 из 1
Форумы / PostgreSQL [игнор отключен] [закрыт для гостей] / 2 индекс не работает.
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]