|  | 
| 
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: | 8ms | 
| get forum list: | 13ms | 
| check forum access: | 3ms | 
| check topic access: | 3ms | 
| track hit: | 44ms | 
| get topic data: | 13ms | 
| get forum data: | 3ms | 
| get page messages: | 47ms | 
| get tp. blocked users: | 2ms | 
| others: | 264ms | 
| total: | 400ms | 

| 0 / 0 | 
