| 69 | == Што е важно за индекси (TL;DR): |
| 70 | |
| 71 | Примарните клучеви → автоматски се индексирани |
| 72 | |
| 73 | Странските клучеви → создај индекс за подобар JOIN |
| 74 | |
| 75 | Филтрирање по колони (WHERE) → индекс помага |
| 76 | |
| 77 | Сортирање и групирање (ORDER BY, GROUP BY) → индекс помага |
| 78 | |
| 79 | -- Индекси за JOIN перформанси (врз странски клучеви и ID полиња) |
| 80 | |
| 81 | CREATE INDEX IF NOT EXISTS idx_policy_package_code ON project_2425.policy(package_code); |
| 82 | CREATE INDEX IF NOT EXISTS idx_policy_d_embg ON project_2425.policy(d_embg); |
| 83 | |
| 84 | CREATE INDEX IF NOT EXISTS idx_pol_dog_c_id ON project_2425.pol_dog(c_id); |
| 85 | |
| 86 | CREATE INDEX IF NOT EXISTS idx_payment_policy_id ON project_2425.payment(policy_id); |
| 87 | |
| 88 | CREATE INDEX IF NOT EXISTS idx_auto_pol_pol_id ON project_2425.auto_pol(pol_id); |
| 89 | CREATE INDEX IF NOT EXISTS idx_auto_pol_v_id ON project_2425.auto_pol(v_id); |
| 90 | |
| 91 | CREATE INDEX IF NOT EXISTS idx_property_pol_pol_id ON project_2425.property_pol(pol_id); |
| 92 | CREATE INDEX IF NOT EXISTS idx_property_pol_prop_id ON project_2425.property_pol(prop_id); |
| 93 | |
| 94 | CREATE INDEX IF NOT EXISTS idx_travel_pol_pol_id ON project_2425.travel_pol(pol_id); |
| 95 | CREATE INDEX IF NOT EXISTS idx_travel_pol_o_embg ON project_2425.travel_pol(o_embg); |
| 96 | |
| 97 | CREATE INDEX IF NOT EXISTS idx_covers_package_code ON project_2425.covers(package_code); |
| 98 | |
| 99 | -- Индекси за WHERE филтри (датуми, email, суми, итн.) |
| 100 | |
| 101 | CREATE INDEX IF NOT EXISTS idx_policy_s_date ON project_2425.policy(s_date); |
| 102 | CREATE INDEX IF NOT EXISTS idx_policy_e_date ON project_2425.policy(e_date); |
| 103 | |
| 104 | CREATE INDEX IF NOT EXISTS idx_customer_email ON project_2425.customer(email); |
| 105 | CREATE INDEX IF NOT EXISTS idx_customer_type ON project_2425.customer(type); |
| 106 | |
| 107 | CREATE INDEX IF NOT EXISTS idx_payment_date ON project_2425.payment(p_date); |
| 108 | CREATE INDEX IF NOT EXISTS idx_payment_amount ON project_2425.payment(p_amount); |
| 109 | |
| 110 | CREATE INDEX IF NOT EXISTS idx_package_type_pol ON project_2425.package(type_pol); |
| 111 | |
| 112 | -- Индекси за уникатни вредности (ако има смисла) |
| 113 | |
| 114 | CREATE UNIQUE INDEX IF NOT EXISTS idx_customer_email_unique ON project_2425.customer(email); |
| 115 | CREATE UNIQUE INDEX IF NOT EXISTS idx_vehicle_license_plate_unique ON project_2425.vehicle(license_plate); |
| 116 | |
| 117 | Тестирање на CREATE INDEX наредби |
| 118 | |
| 119 | [[Image(Index1.png)]] |
| 120 | |
| 121 | == Додатни чекори за оптимизација на индекси со EXPLAIN ANALYZE |
| 122 | |
| 123 | Сега ке направиме мало тестирање со опцијата во прилог, |
| 124 | доколку Dbeaver користи Seq Scan (Sequence Scan), значи дека треба подобар индекс. |
| 125 | {{{ EXPLAIN ANALYZE SELECT * FROM project_2425."policy" WHERE s_date BETWEEN '2023-01-01' AND '2025-12-31'; }}} |
| 126 | |
| 127 | Бидејки на ова барање добивме одговор со Seq Scan наместо со Index Scan, |
| 128 | ова во наш случај не би требало да е проблем бидејки базата нема премногу податоци и табелите се мали. |