215 похожих чатов

Коллеги, подскажите почему следующий запрос не использует индексы для поиска

field_v ( есть составной индекс (field_v, field_c):
box.execute([[EXPLAIN SELECT * FROM (SELECT * FROM "tbl_h" WHERE "start_date" <= 86 AND "end_date" >= 86 UNION ALL SELECT * FROM "test_a" WHERE "start_date" <= 86) AS "t3" WHERE ("field_v" = 'test' OR "field_v2" = 'test' OR ("field_vcn" = 'test' OR "field_vbn" = 'test')) AND "field_c" = 1]])


План выполнения:
---
- metadata:
- name: selectid
type: integer
- name: order
type: integer
- name: from
type: integer
- name: detail
type: text
rows:
- [1, 0, 0, 'SEARCH TABLE tbl_h USING COVERING
INDEX x_start_date (start_date<?) (~212992 rows)']
- [2, 0, 0, 'SEARCH TABLE test_a USING COVERING
INDEX x_start_date (start_date<?) (~229376 rows)']
- [0, 0, 0, 'COMPOUND SUBQUERIES 1 AND 2 (UNION ALL)']

2 ответов

22 просмотра
Igor Kuznetsov- Автор вопроса

Коллеги подскажите в чем проблема?

Насколько я вижу вы сначала выбираете значения в подзапросе по полям end_date и start_date, а потом уже на результатах подзапроса делаете еще один select и в данном случае составной индекс (field_v, field_c) безполезен

Похожие вопросы

Обсуждают сегодня

30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Карта сайта