Diskuze: Ukládání kreditu
V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.
Člen
Zobrazeno 12 zpráv z 12.
//= 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.
Rozhodně chceš mít uložené transakce a z nich počítat stav konta. Už
jenom proto, že uživatele pravděpodobně bude zajímat, proč a kdy mu
zmizel/přibyl kredit. Navíc budeš mít případně možnost pohodlně řešit
storno a refundace.
// Dost pravděpodobně chceš tabulku transakcí všech uživatelů, ne jen
jednoho uživatele.
Díky. A to vypočítávání bys dělal automaticky jako trigger při každém vložení záznamu do tabulky, a ukládal konečný stav creditu do vlastního políčka, nebo udržoval sloupec trvale dynamický třeba v pohledu, nebo to počítat až přímo pro potřebu scriptu?
Za předpokladu, že ten stav kreditu bude hodně dynamický
Nejdřív bych to udělal jednoduše bez triggeru. Pokud bys měl hodně čtení a výrazně tě to zpomalovalo, pak bych zauvažoval nad přidáním indexu nebo triggeru. Ale nejsem žádněj velikej databázista.
Viděl bych lepší držet u uživatele i aktuální stav kreditu. Tedy
nepočítat to pokaždé dynamicky. Až bude mít hromadu transakcí, bude to
zbytečně zdržovat.
Prostě po každé transakci (plus, minus, storno, refund apod...) uložit
transakci do tabulky transakcí a zároveň spočítat uživateli aktuální
kredit a ten si držet u jeho id.
Když bude mít hodně úprav (což předpokládá), pak ho naopak bude přepočítávání při každé změně brzdit.
Jo, asi bude třeba rozhodnout , kde bude důležitější být rychlejší a kde naopak bude možná prodleva.
A co udělat tabulku , do které ukládat všechny transakce a pro potřebu aplikace vytvořit MySQL pohled, který bude mít třeba jen sloupec id a kredit - udržovaný pomocí aggregované funkce z té tabulky, a s tou hodnotou dále pracovat v aplikaci?
Bude to mít nějaký pozitivní význam? Potřebuji zajistit, aby aplikace neumožnovala akce v případě záporného kreditu, tech změn bude tak 20 za minutu pro jednoho uživatele.
Pohledem můžeš shovávat komplexnější kód, ale výkonnostně ti to nijak nepomůže.
A ještě malý dotaz, je lepší mít samostatné tabulky pro ruzné druhy operací dobití kreditu / odeslání kreditu, nebo jedna a věnovat tomu sloupec pro odlišení a operovat se znaménky?
Určitě bych to dal do jedné tabulky a ke každému záznamu přidával ID typu transakce. Jednak se ti s tím bude mnohem líp pracovat až budeš tvořit nějaký komplexnější dotaz a jednak kdybys chtěl s těma kreditama dělat něco dalšího (třeba mít ještě další stavy "čeká na připsání", "čeká na platbu" apod.) tak bys musel přidávat do databáze další tabulky a upravovat dotazy a to není moc systematické.
Zobrazeno 12 zpráv z 12.