|
2 / 2 / 1
Регистрация: 16.04.2022
Сообщений: 1,004
|
||||||
Долгий DISTINCT06.03.2024, 09:16. Показов 1132. Ответов 11
Метки нет (Все метки)
Здравствуйте!
Есть большая таблица из 60 столбцов и 1 млрд строк. Есть индекс с составными полями (10 колонок). Когда запускаю запрос, который часто вызывается
Как можно ускорить такой запрос, чтобы в системе хранилась подобная статистика?
0
|
||||||
| 06.03.2024, 09:16 | |
|
Ответы с готовыми решениями:
11
DISTINCT дублирует значения Как написать self join запрос исключив дубликаты без использования distinct? distinct |
|
5393 / 1465 / 513
Регистрация: 31.05.2012
Сообщений: 5,153
|
|
| 06.03.2024, 09:32 | |
|
Distinct по сути неявный group by по всем полям выборки, по периоду в данном случае. Где тот период в индексе? Можно сделать дополнительную табличку с ключом период и на нее повесить внешний ключ с проблемной таблицы. Тогда запрос ускорится и делать его на доп.таблицу.
0
|
|
|
912 / 286 / 57
Регистрация: 01.06.2023
Сообщений: 803
|
|
| 06.03.2024, 11:00 | |
|
В явном виде индекс не используется, но можно заставить при правильно составленном запросе. https://wiki.postgresql.org/wiki/Loose_indexscan
0
|
|
|
2 / 2 / 1
Регистрация: 16.04.2022
Сообщений: 1,004
|
|||||||||||
| 06.03.2024, 12:00 [ТС] | |||||||||||
|
Используется обычный индекс
0
|
|||||||||||
|
912 / 286 / 57
Регистрация: 01.06.2023
Сообщений: 803
|
|
| 06.03.2024, 12:14 | |
|
Для того что бы индекс использовался, искомое поле должно быть слева в противном случае не иаеет смысла
1
|
|
|
2 / 2 / 1
Регистрация: 16.04.2022
Сообщений: 1,004
|
||
| 07.03.2024, 08:56 [ТС] | ||
|
Добавлено через 25 минут и в результате все равно долго.
0
|
||
|
912 / 286 / 57
Регистрация: 01.06.2023
Сообщений: 803
|
|
| 07.03.2024, 09:13 | |
|
В PG что бы получить уникальные записи нужно просканировать всю таблицу. Пробовали метод из поста Долгий DISTINCT
0
|
|
|
1302 / 356 / 97
Регистрация: 14.10.2022
Сообщений: 1,084
|
||
| 09.03.2024, 11:55 | ||
|
https://habr.com/ru/companies/... es/329542/ См. раздел "Грабли" "Отсутствие cross column статистики (многомерных распределений)". Наслаждайтесь.
0
|
||
|
Просто Лис
|
||
| 09.03.2024, 18:43 | ||
|
Если запрос
SELECT DISTINCT "Период" FROM test.myTable1; нужно реально часто выполнять, то можно позаимствовать идеюtest.myTable1 накинуть триггеры на update/insert/delete. В отдельной таблице поля "Период" (UK) и "Количество" (int). Этакая статистика для бедных.Минусы: глупо, хрупко. Плюсы: быстро
0
|
||
|
2 / 2 / 1
Регистрация: 16.04.2022
Сообщений: 1,004
|
||||||
| 29.03.2024, 08:20 [ТС] | ||||||
|
Есть такой вариант
Кликните здесь для просмотра всего текста
Lower используется потому что там будет переменная. Используется поле "most_common_vals". В документации это Список самых частых значений в столбце. (NULL, если не находятся значения, встречающиеся чаще других.) Если указано, что выводит самые частые значения, то возможно может не вывести все значения. Что скажете по такому варианту?
0
|
||||||
|
Просто Лис
|
|
| 29.03.2024, 16:08 | |
|
Я не стал бы использовать
pg_stats для боевых запросов. Что-либо прикинуть - да, точный ответ - нет.Но надо опять же читать документацию, сомневаюсь, что в pg_stats точность прямо до одной строки.
0
|
|
|
2 / 2 / 1
Регистрация: 16.04.2022
Сообщений: 1,004
|
|
| 31.03.2024, 17:41 [ТС] | |
|
Спасибо!
0
|
|
| 31.03.2024, 17:41 | |
|
Помогаю со студенческими работами здесь
12
DISTINCT Select distinct ... Distinct и COUNT INSERT INTO Distinct Нестандартный DISTINCT Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
||||
|
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта
Симптом:
После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
|
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
|
Новый ноутбук
volvo 07.12.2025
Всем привет.
По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне:
Ryzen 5 7533HS
64 Gb DDR5
1Tb NVMe
16" Full HD Display
Win11 Pro
|
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
|
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
|
|
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов
На странице:
https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/
нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
|
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов.
. . .
|
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
|
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
|
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут.
В век Веб все очень привыкли к дизайну Single-Page-Application .
Быстренько разберем подход "на фреймах".
Мы делаем одну. . .
|