| | 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 | ова во наш случај не би требало да е проблем бидејки базата нема премногу податоци и табелите се мали. |