| | 1 | = Индекс: v_driver_lunch_timers_index = |
| | 2 | |
| | 3 | ||= Датотека ||= `indexes/v_driver_lunch_timers_index.sql` || |
| | 4 | ||= Шема ||= `kbnteam` || |
| | 5 | ||= Поврзани прегледи ||= `v_driver_lunch_timers`, `v_company_users` || |
| | 6 | |
| | 7 | == Опис == |
| | 8 | Три индекси за поддршка на прегледот `v_driver_lunch_timers`. Таргетираат: распоред по ден од неделата, JOIN на возачи по ресторан и JOIN на договори по ресторан и компанија. |
| | 9 | |
| | 10 | == DDL == |
| | 11 | {{{ |
| | 12 | #!sql |
| | 13 | -- indexes/v_driver_lunch_timers_index.sql |
| | 14 | CREATE INDEX IF NOT EXISTS idx_lunch_time_weekday_contract_id |
| | 15 | ON kbnteam.lunch_time (lunch_weekday, contract_id); |
| | 16 | |
| | 17 | CREATE INDEX IF NOT EXISTS idx_driver_rest_id |
| | 18 | ON kbnteam.driver (rest_id); |
| | 19 | |
| | 20 | CREATE INDEX IF NOT EXISTS idx_contract_rest_id_company_id |
| | 21 | ON kbnteam.contract (rest_id, company_id); |
| | 22 | }}} |
| | 23 | |
| | 24 | == Поддржани прегледи == |
| | 25 | ||= Индекс ||= Прегледи ||= Цел || |
| | 26 | || `idx_lunch_time_weekday_contract_id` || `v_driver_lunch_timers` || WHERE `lunch_weekday = ?`; JOIN `lunch_time` → `contract` || |
| | 27 | || `idx_driver_rest_id` || `v_driver_lunch_timers`, `v_driver_deliveries`, `v_company_users` || JOIN `driver ON drv.rest_id = r.rest_id` || |
| | 28 | || `idx_contract_rest_id_company_id` || `v_driver_lunch_timers` || JOIN `contract` по `rest_id` (complement на `idx_contract_company_id_rest_id`) || |
| | 29 | |
| | 30 | == Колонски план == |
| | 31 | ||= Индекс ||= Колона 1 ||= Колона 2 ||= Причина || |
| | 32 | || `idx_lunch_time_weekday_contract_id` || `lunch_weekday` (leading) || `contract_id` || Филтрирање по ден; JOIN со `contract` по `contract_id` || |
| | 33 | || `idx_driver_rest_id` || `rest_id` || — || JOIN `driver.rest_id` = `restaurant.rest_id` || |
| | 34 | || `idx_contract_rest_id_company_id` || `rest_id` (leading) || `company_id` || JOIN `contract` по `rest_id` наместо по `company_id` || |
| | 35 | |
| | 36 | == Верификација == |
| | 37 | {{{ |
| | 38 | #!sql |
| | 39 | SELECT indexname, indexdef |
| | 40 | FROM pg_indexes |
| | 41 | WHERE schemaname = 'kbnteam' |
| | 42 | AND indexname IN ( |
| | 43 | 'idx_lunch_time_weekday_contract_id', |
| | 44 | 'idx_driver_rest_id', |
| | 45 | 'idx_contract_rest_id_company_id' |
| | 46 | ); |
| | 47 | }}} |
| | 48 | |
| | 49 | == Напомена — `idx_contract_rest_id_company_id` наспрема `idx_contract_company_id_rest_id` == |
| | 50 | ||= Индекс ||= Leading колона ||= Цел || |
| | 51 | || `idx_contract_company_id_rest_id` || `company_id` || Прашалници и JOIN по компанија → ресторан (дефиниран во `v_contracts_revenue_index.sql`) || |
| | 52 | || `idx_contract_rest_id_company_id` || `rest_id` || Прашалници и JOIN по ресторан → компанија (овој индекс) || |
| | 53 | |
| | 54 | Двата постојат паралелно за да ги поддржат различните насоки на JOIN во различните прегледи. |