Changes between Initial Version and Version 1 of DriverLunchTimersIndex


Ignore:
Timestamp:
05/10/26 14:44:26 (2 weeks ago)
Author:
185022
Comment:

--

Legend:

Unmodified
Added
Removed
Modified
  • DriverLunchTimersIndex

    v1 v1  
     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
     14CREATE INDEX IF NOT EXISTS idx_lunch_time_weekday_contract_id
     15ON kbnteam.lunch_time (lunch_weekday, contract_id);
     16
     17CREATE INDEX IF NOT EXISTS idx_driver_rest_id
     18ON kbnteam.driver (rest_id);
     19
     20CREATE INDEX IF NOT EXISTS idx_contract_rest_id_company_id
     21ON 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
     39SELECT indexname, indexdef
     40FROM pg_indexes
     41WHERE 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 во различните прегледи.