Diskuze: Návrh databáze
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Tvůrce
Zobrazeno 14 zpráv z 14.
//= Settings::TRACKING_CODE_B ?> //= Settings::TRACKING_CODE ?>
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Důvod také proč píšu je ten, abych to měl kvalitně navrhnuté a nemusel to pak zbytečně předělávat, protože daná varianta je nevýkonná.
Zásada je, že každá tabulka by se v podstatě měla starat o jednu věc. Tabulka uživatelů se "stará" o užvatele, tabulka článků o články, tabulka komentářů o komentáře atd. Tyto tabulky se "propojují" buď cizími klíči (třeba v tabulce články je jako cizí klíč ID autora, v tabulce komentáře je taky ID autora a ještě k tomu ID článku, atd.), nebo další, tzv. "vazební" tabulkou v případě, že chceš mít vztah M:M (například třeba v případě přiřazování rolí uživatele - jeden uživatel může mít více rolí a zároveň jedna role má více uživatelů)...
Ok, díky.
Jak ale řešit chat? Tam nevím jak popsaný princip použít.
Chat jsem sice nikdy neřešil, ale asi bych spáchal tabulku, kde by bylo ID
záznamu, ID odesílatele, ID příjemce, Datum, Text, přičemž ID záznamu by
byl auto_increment, ID odesílatele a ID příjemce by byly cizí klíče z
tabulky Users a zobrazování bych řešil dotazem, kde by byla podmínka že ID
odesílatele nebo ID příjemce se rovná ID přihlášeného uživatele...
Pak už stačí nějak pořešit automatický refresh při přijetí nové
zprávy...
Je toto řešení dosti výkonné? Já se bojím, že když tak bude příliš mnoho záznamů, tak to může být dost pomalé, zas na druhou stranu nevím jak jinak by se to dalo vyřešit.
Chat asi není třeba nějak dlouho archivovat, lze ho průběžně odmazávat. Co si představuješ pod pojmem "příliš mnoho záznamů"?
Teoreticky to můžu časem i promazávat, ale řekněme že bych to
nedělal.
Dejme tomu, že by bylo 1000 uživatelů a kdyby každý napsal třeba 1000
zpráv, tak to už je docela dost záznamů.
Pak už je jen třeba zvolit tu správnou databázi. Nedělám v PHP, takže nevím, co všechno zvládne MySQL, ale MSSQL toto musí zvládnout v pohodě. Otázkou spíš je, jestli je skutečně k něčemu potřebné takové množství dat uchovávat. Pokud skutečně ano, pak bych ještě přidal tabulku "archiv" a tam bych přesunoval starší záznamy, protože v "ostrých" datech k aktivní komunikaci je takové množství dat zbytečné, zobrazovat budeš stejně jen posledních cca 10 záznamů v chatu obou uživatelů...
a co takto automaticky priebezne stare zaznamy premazavat?
napriklad v urcity cas, alebo ked uzivatel odosle spravu?
Zobrazeno 14 zpráv z 14.