Этот баннер — требование Роскомнадзора для исполнения 152 ФЗ.
«На сайте осуществляется обработка файлов cookie, необходимых для работы сайта, а также для анализа использования сайта и улучшения предоставляемых сервисов с использованием метрической программы Яндекс.Метрика. Продолжая использовать сайт, вы даёте согласие с использованием данных технологий».
Политика конфиденциальности
|
|
|
TOP from Full Text Search
|
|||
|---|---|---|---|
|
#18+
Подскажите пожалуйста, есть табличка на 3 млн строк с PK. Нужно получить TOP50 последних значений (по дате) при существующем FullText индексе. Т.е. нужно: Код: sql 1. 2. 3. 4. Такой запрос работает больше минуты (ФТС находит 450 тыс. строк, потом мапит на PK, потом сортирует и потом возвращает первые 50). Индекс по дате есть, но он не используется (судя по плану). При этом вот такой запрос: Код: sql 1. 2. 3. работает 1 секунду. Как правильно скрестить слона с носорогом? Код: sql 1. делает только хуже. Заполнять темповую таблицу с 450 тыс строк- больше 40 секунд... Использовать like - больше 13 секунд... А надо 3-4 сек, не больше... Можно ли как-то ФТС индекс завязать с датой и отсортировать? Понимаю, что бред, но всё же... Код: sql 1. 2. Хелп! :) ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.04.2019, 11:35 |
|
||
|
TOP from Full Text Search
|
|||
|---|---|---|---|
|
#18+
igor2222, не уверен, но попробуйте построить кластерный индекс по StartDate. Некластерный не сможет повлиять на порядок просмотра записей таблицы. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.04.2019, 11:59 |
|
||
|
TOP from Full Text Search
|
|||
|---|---|---|---|
|
#18+
Если PK кластерный, попробуйте так Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.04.2019, 12:26 |
|
||
|
TOP from Full Text Search
|
|||
|---|---|---|---|
|
#18+
Владислав Колосовigor2222, не уверен, но попробуйте построить кластерный индекс по StartDate. Некластерный не сможет повлиять на порядок просмотра записей таблицы. К сожалению, не вариант. PK кластерный. На него завязаны форейны. Я положу остальной перфоманс... ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.04.2019, 12:53 |
|
||
|
TOP from Full Text Search
|
|||
|---|---|---|---|
|
#18+
invmЕсли PK кластерный, попробуйте так... Спасибо, но пока не получилось :( Весь селект остановил после 4х минут... Внутренний с сортировкой остановил после 4х минут... Внутренний без сортировки тоже не дождался... А вот Код: sql 1. выбрал 659 тыс за 5 сек... Как бы умудриться его сортирнуть на лету? ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.04.2019, 13:00 |
|
||
|
TOP from Full Text Search
|
|||
|---|---|---|---|
|
#18+
igor2222Весь селект остановил после 4х минут... Внутренний с сортировкой остановил после 4х минут... Внутренний без сортировки тоже не дождался...Лучше планы показывать, хотя бы оценочные. И не картинкой, а в формате sqlplan igor2222Как бы умудриться его сортирнуть на лету?Никак. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.04.2019, 13:26 |
|
||
|
TOP from Full Text Search
|
|||
|---|---|---|---|
|
#18+
igor2222, Можете попробовать вот такой изврат: 1. Добавить в таблицу вычисляемый столбец Код: sql 1. и добавить его в FTI. Также выключить стоп-лист. 2. Написать функцию: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. 12. 13. 14. 15. 16. 3. Обеспечить в БД заполненую таблицу натуральных чисел, начиная с нуля. 4. Переписать запрос так: Код: sql 1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 11. ... |
|||
|
:
Нравится:
Не нравится:
|
|||
| 09.04.2019, 14:00 |
|
||
|
|

start [/forum/topic.php?fid=46&msg=39798649&tid=1687958]: |
0ms |
get settings: |
6ms |
get forum list: |
14ms |
check forum access: |
2ms |
check topic access: |
2ms |
track hit: |
51ms |
get topic data: |
10ms |
get forum data: |
3ms |
get page messages: |
60ms |
get tp. blocked users: |
1ms |
| others: | 258ms |
| total: | 407ms |

| 0 / 0 |
