Partycjonowanie natywne
Wprowadzenie
O co chodzi?
Partycjowanie to podzielenie jednej dużje tabelki na fizyczne, mniejsze cześci - partycje. Nad nimi czuwa
Po co stosujemy partycjonowanie?
Podstawową korzyścią jakie daje
Po czym należy partycjonowac?
po kolumnie która będzie najcześciej używana w selectach i która wraz z odpowiednim trbem partycjonowania (list, range, hash) da w miarę równe rozłożenie rekordów po partycjach.
Schemat najczęściej stosowany w BM - partition by range +createtime

Mamy tu:
tabelę spartycjonowana o nazwie parent po kolumnie createtime, nazywaną dalej rodzicem
klucz główny - zwróć uwagę, że musi zawierać kolumne, po której partycjonujemy, bywa to uciążliwe szczególnie w wypadku partycjonowania po timestampie utworzenia rekordu
kolumna timestamp z datą utworzenia rekordu
korzyści
podkreślić, że nie zawsze to jest najlepszy model partycjonowania
Zarządzanie partycjami
W planach jest zbudowanie automatu który będzie w stanie
Listowanie partycjonowanych tabel
Dodawanie partycji
Utworzenie nowych tabel i jednoczesne dodanie ich jako partycje
W linii:
4. Ustawiasz interwał, jakiego ma dotyczyć partycja
7. wskazujesz dla jakiego przedziału czasu maja być partycje utworzone
11. wskazujesz nazwę rodzica
12. zakomentowano przykład, jak dla utworzyć partycje dla kolejnych rodziców w jednym zapytaniu
Wyrównanie indeksacji
Poniższy sql wylsituje sqle do tworzenia brakujących indexów. Działa na zasadzie porównania dwóch partycji.
Do zmiany:
linia 3 - parent
linia 4,5 - suffix z datą partycji - np. tylko '2022_12'
Dodanie istniejącej tabeli jako partycji
Usuwanie partycji
Indeksowanie
W linii:
Tworzymy indeks na rodzicu - dzięki temu każda partycja, która powstanie będzie miała ten indeks
używamy klauzuli ONLY - indeks na tym moment powstanie tylko na rodzicu, ale ponieważ na tabeli spartycjonowanej nie możemy użyć CONCURRENTLY, znacząco skróci nam to locka
Tworzymy indeks na partycji / partycjach
ważne jest to, że niekoniecznie zawsze będziemy chcieli, żeby wszystkie partycje miały ten indeks
Tu już możemy użyć CONCURRENTLY
Dodajemy indeks partycji do indeksu głównego na rodzicu
dzięki temu do każdego
Koniecznie wykonujemy ANALYZE, optymalnie możemy wykonać VACUUM ANALYZE;
When CREATE INDEX is invoked on a partitioned table, the default behavior is to recurse to all partitions to ensure they all have matching indexes. Each partition is first checked to determine whether an equivalent index already exists, and if so, that index will become attached as a partition index to the index being created, which will become its parent index. If no matching index exists, a new index will be created and automatically attached; the name of the new index in each partition will be determined as if no index name had been specified in the command. If the ONLY option is specified, no recursion is done, and the index is marked invalid. (ALTER INDEX ... ATTACH PARTITION marks the index valid, once all partitions acquire matching indexes.) Note, however, that any partition that is created in the future using CREATE TABLE ... PARTITION OF will automatically have a matching index, regardless of whether ONLY is specified.