NOVINKA! E-learningové kurzy umělé inteligence. Nyní AI za nejlepší ceny. Zjisti více:
NOVINKA – Víkendový online kurz Software tester, který tě posune dál. Zjisti, jak na to!

Diskuze: Návrh databáze

V předchozím kvízu, Online test znalostí PHP, jsme si ověřili nabyté zkušenosti z kurzu.

Aktivity
Avatar
Vakos
Tvůrce
Avatar
Vakos:6.5.2017 16:52

Ahoj, dělám web, kde řeším problémy s návrhem databáze.

  1. Komentáře u článku - Jak se ukládají komentáře, které jsou napsané u článku? Chápu, že článek, má vždy svůj záznam v DB v seznamu článků, ale jak ukládat do DB články?
  2. Chat uživatelů - Jak uložit chat dvou uživatelů či více uživatelů?
Odpovědět
6.5.2017 16:52
"Jediný způsob, jak dělat skvělou práci, je milovat to, co děláte. Pokud jste to ještě nenašli, hledejte dál. Ne...
Avatar
Eda Stehlík
Člen
Avatar
Eda Stehlík:6.5.2017 16:55
  1. U komentáře dej v tabulce řádku id_clanek nebo něco podobneho kam budes ukladat id clanku, u ktereho je komentář
  2. Zkusil bych vygooglit už nějaké hotové řešení, kde bude například i ajax
Editováno 6.5.2017 16:56
 
Nahoru Odpovědět
6.5.2017 16:55
Avatar
Vakos
Tvůrce
Avatar
Odpovídá na Eda Stehlík
Vakos:6.5.2017 16:59
  1. Komentáře: Takže bude tabulka pouze pro komentáře, kde bude uloženo ID článku, kde byl komentář napsán a samotný text komentáře?
  2. chat: Googlit jsem zkoušel, ale nenašel jsem to, takže se ptám zde na fóru.
Nahoru Odpovědět
6.5.2017 16:59
"Jediný způsob, jak dělat skvělou práci, je milovat to, co děláte. Pokud jste to ještě nenašli, hledejte dál. Ne...
Avatar
Eda Stehlík
Člen
Avatar
Odpovídá na Vakos
Eda Stehlík:6.5.2017 17:08
  1. Přesně tak
  2. Našel jsem http://vavru.cz/ajax/vchat/ asi to není to co hledáš, ale mohlo by to pomoct. Jinak zkus vygooglit ajax chat, to mi vyhodilo celkem dost výsledků. Já bych ale ukládal do tabulky třeba chat s řádky id, odesilatel, prijemce(kdyz pro vsechny tak 0), text. A jenom bych pak na zobrazování použil ajax
Editováno 6.5.2017 17:10
 
Nahoru Odpovědět
6.5.2017 17:08
Avatar
Vakos
Tvůrce
Avatar
Odpovídá na Eda Stehlík
Vakos:6.5.2017 19:00
  1. Je to dostatečně výkonná varianta?
  2. Googlil jsem a nic moc jsem nenašel.

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á.

Nahoru Odpovědět
6.5.2017 19:00
"Jediný způsob, jak dělat skvělou práci, je milovat to, co děláte. Pokud jste to ještě nenašli, hledejte dál. Ne...
Avatar
Odpovídá na Vakos
Michal Štěpánek:6.5.2017 19:36

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ů)...

Nahoru Odpovědět
6.5.2017 19:36
Nikdy neříkej nahlas, že to nejde. Vždycky se totiž najde blbec, který to neví a udělá to...
Avatar
Vakos
Tvůrce
Avatar
Odpovídá na Michal Štěpánek
Vakos:6.5.2017 20:49

Ok, díky.

Jak ale řešit chat? Tam nevím jak popsaný princip použít.

Nahoru Odpovědět
6.5.2017 20:49
"Jediný způsob, jak dělat skvělou práci, je milovat to, co děláte. Pokud jste to ještě nenašli, hledejte dál. Ne...
Avatar
Odpovídá na Vakos
Michal Štěpánek:6.5.2017 22:23

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...

Akceptované řešení
+20 Zkušeností
+2,50 Kč
Řešení problému
Nahoru Odpovědět
6.5.2017 22:23
Nikdy neříkej nahlas, že to nejde. Vždycky se totiž najde blbec, který to neví a udělá to...
Avatar
Vakos
Tvůrce
Avatar
Odpovídá na Michal Štěpánek
Vakos:6.5.2017 23:09

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.

Nahoru Odpovědět
6.5.2017 23:09
"Jediný způsob, jak dělat skvělou práci, je milovat to, co děláte. Pokud jste to ještě nenašli, hledejte dál. Ne...
Avatar
Odpovídá na Vakos
Michal Štěpánek:6.5.2017 23:18

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ů"?

Nahoru Odpovědět
6.5.2017 23:18
Nikdy neříkej nahlas, že to nejde. Vždycky se totiž najde blbec, který to neví a udělá to...
Avatar
Vakos
Tvůrce
Avatar
Odpovídá na Michal Štěpánek
Vakos:6.5.2017 23:31

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ů.

Nahoru Odpovědět
6.5.2017 23:31
"Jediný způsob, jak dělat skvělou práci, je milovat to, co děláte. Pokud jste to ještě nenašli, hledejte dál. Ne...
Avatar
Odpovídá na Vakos
Michal Štěpánek:7.5.2017 9:59

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ů...

Nahoru Odpovědět
7.5.2017 9:59
Nikdy neříkej nahlas, že to nejde. Vždycky se totiž najde blbec, který to neví a udělá to...
Avatar
mkub
Tvůrce
Avatar
Odpovídá na Vakos
mkub:7.5.2017 15:02

a co takto automaticky priebezne stare zaznamy premazavat?
napriklad v urcity cas, alebo ked uzivatel odosle spravu?

 
Nahoru Odpovědět
7.5.2017 15:02
Avatar
Vakos
Tvůrce
Avatar
Vakos:7.5.2017 16:09

Děkuji všem za odpovědi. Chat tedy vyřeším tak, že vše budu cpát do jedné databáze a staré zprávy mazat.

Nahoru Odpovědět
7.5.2017 16:09
"Jediný způsob, jak dělat skvělou práci, je milovat to, co děláte. Pokud jste to ještě nenašli, hledejte dál. Ne...
Děláme co je v našich silách, aby byly zdejší diskuze co nejkvalitnější. Proto do nich také mohou přispívat pouze registrovaní členové. Pro zapojení do diskuze se přihlas. Pokud ještě nemáš účet, zaregistruj se, je to zdarma.

Zobrazeno 14 zpráv z 14.