|
EXPLAIN QUERY PLAN: не срабатывает индекс
|
|||
---|---|---|---|
#18+
Таблица (древовидной структуры): Код: sql 1. 2. 3. 4. 5. 6. 7.
1. Есть запрос: Код: sql 1. 2. 3. 4.
Результат: Код: sql 1. 2.
Меня смущает вот это: SCAN TABLE MyTable AS T2 2. При том что запрос: Код: sql 1. 2. 3. 4.
Даёт такой результат: Код: sql 1.
Вопрос: Можно как-то решить использование индекса IDX_MyTable_Sub для первого запроса? ... |
|||
:
Нравится:
Не нравится:
|
|||
16.06.2018, 22:56 |
|
EXPLAIN QUERY PLAN: не срабатывает индекс
|
|||
---|---|---|---|
#18+
Можно. Но не нужно. Можно. Читать тут как работает оптимизатор и там же есть подсказки по ручному упарвлению: https://sqlite.org/optoverview.html Не нужно. Потому что у тебя идет связь сам-с-собой. При этом, T2 - ничем не лимитирована, а T1 лимитирована по T2. Таким образом и получается что по T2 надо делать полный скан, а по T1 только те записи что отмечены в T2. То есть оптимизатор тебе уже нашел идеальный план для твоей ситуации. ... |
|||
:
Нравится:
Не нравится:
|
|||
17.06.2018, 04:30 |
|
|
start [/forum/topic.php?desktop=1&fid=54&tid=2008447]: |
0ms |
get settings: |
10ms |
get forum list: |
13ms |
check forum access: |
4ms |
check topic access: |
4ms |
track hit: |
41ms |
get topic data: |
13ms |
get forum data: |
3ms |
get page messages: |
45ms |
get tp. blocked users: |
1ms |
others: | 286ms |
total: | 420ms |
0 / 0 |