abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
AbcLinuxu hledá autory!
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    včera 15:00 | Zajímavý článek

    Byl publikován přehled vývoje renderovacího jádra webového prohlížeče Servo (Wikipedie) za uplynulé dva měsíce. Servo zvládne už i Gmail. Zakázány jsou příspěvky generované pomocí AI.

    Ladislav Hagara | Komentářů: 1
    9.5. 17:22 | Nová verze

    Raspberry Pi Connect, tj. oficiální služba Raspberry Pi pro vzdálený přístup k jednodeskovým počítačům Raspberry Pi z webového prohlížeče, byla vydána v nové verzi 2.5. Nejedná se už o beta verzi.

    Ladislav Hagara | Komentářů: 0
    9.5. 15:22 | Komunita

    Google zveřejnil seznam 1272 projektů (vývojářů) od 185 organizací přijatých do letošního, již jednadvacátého, Google Summer of Code. Plánovaným vylepšením v grafických a multimediálních aplikacích se věnuje článek na Libre Arts.

    Ladislav Hagara | Komentářů: 0
    8.5. 19:22 | Nová verze

    Byla vydána (𝕏) dubnová aktualizace aneb nová verze 1.100 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.100 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    8.5. 18:00 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.5.

    Ladislav Hagara | Komentářů: 0
    8.5. 01:22 | Nová verze Ladislav Hagara | Komentářů: 0
    8.5. 00:55 | Zajímavý projekt

    PyXL je koncept procesora, ktorý dokáže priamo spúštat Python kód bez nutnosti prekladu ci Micropythonu. Podľa testov autora je pri 100 MHz približne 30x rýchlejší pri riadeni GPIO nez Micropython na Pyboard taktovanej na 168 MHz.

    vlk | Komentářů: 0
    7.5. 19:44 | Nová verze

    Grafana (Wikipedie), tj. open source nástroj pro vizualizaci různých metrik a s ní související dotazování, upozorňování a lepší porozumění, byla vydána ve verzi 12.0. Přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    7.5. 17:33 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2025-05-06. Přehled novinek v příspěvku na blogu Raspberry Pi a poznámkách k vydání. Pravděpodobně se jedná o poslední verzi postavenou na Debianu 12 Bookworm. Následující verze by již měla být postavena na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    7.5. 05:33 | Komunita

    Richard Stallman dnes v Liberci přednáší o svobodném softwaru a svobodě v digitální společnosti. Od 16:30 v aule budovy G na Technické univerzitě v Liberci. V anglickém jazyce s automaticky generovanými českými titulky. Vstup je zdarma i pro širokou veřejnost.

    Ladislav Hagara | Komentářů: 17
    Jaký filesystém primárně používáte?
     (57%)
     (1%)
     (8%)
     (22%)
     (4%)
     (2%)
     (2%)
     (1%)
     (1%)
     (3%)
    Celkem 576 hlasů
     Komentářů: 26, poslední 8.5. 09:58
    Rozcestník

    Dotaz: MySQL: Rozdělit do tabulek, nebo ne?

    15.3.2017 20:32 Hrabosh | skóre: 26 | blog: HBlog | Brno
    MySQL: Rozdělit do tabulek, nebo ne?
    Přečteno: 1345×
    Zdravím,

    co se týká databází, jsem naprostý začátečník. Rozjel jsem MySQL server a do databáze chci ukládat teplotu z čidel v různých místnostech domu v cca 10 minutových intervalech.

    Je lepší vytvořit jednu tabulku a tam mít sloupce čas, datum, místnost, teplota, nebo bude lepší mít separátní tabulku pro každou místnost a sloupce pak jen čas, datum a teplota?

    Díky,

    Z.
    To jsem psal já ... to není bordel, to je modulární!

    Řešení dotazu:


    Odpovědi

    15.3.2017 20:59 NN
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    V pripade samostatnych tabulek odpadne identifikace cidla a nebudes muset data filtrovat, takze bych byl pro samostatnou tabulku na kazdy senzor.
    15.3.2017 21:18 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?

    Rozhodně to první (tedy až na to, že nemá smysl rozdělovat datum a čas do dvou sloupců).

    Ve druhé variantě byste ve frontendu musel pro každou místnost úplně zbytečně generovat vlastní dotaz. A pokud byste zatoužil po výstupu typu "ukaž mi teploty ve všech místnostech v určitém čase", tak to bude oproti první variantě mnohem komplikovanější.

    15.3.2017 21:24 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    No jo, teď teprve vidím, že se snaží dát datum a čas do dvou sloupců. Rozhodně patří do jednoho.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    15.3.2017 21:32 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    Abych to zobecnil: v okamžiku, kdy zjistíte, že potřebujete v dotazu hodnotu nějaké proměnné nebo výrazu použít jako jméno sloupce nebo tabulky, ve většině případů to znamená, že jste strukturu navrhl špatně.
    15.3.2017 21:22 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    Použil bych jednu tabulku. Až přidáš další čidlo, nebudeš muset kvůli tomu měnit aplikaci.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    16.3.2017 09:27 Hrabosh | skóre: 26 | blog: HBlog | Brno
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    Super, dík moc. Zvolím teda jednu tabulku pro teploty ve všech místnostech.
    To jsem psal já ... to není bordel, to je modulární!
    20.3.2017 11:16 j
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    Jinak si pocti vic tabulek pro stejny data odporuje uplne vsemu. Byt se to jako backend pouziva kvuli zvednuti vykonu, ale v takovym pripade by to aplikace jako takova vubec nemela videt. Jediny spravny misto kde urcit jaky data chces je prave where, rozhodne ne from. Viz MK.
    20.3.2017 13:45 VM
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    "jediný správný místo je where" - jojo, umístění měřidla se píše do "WHERE" :-)

    Jinak samozřejmě všechno do jedné tabulky. Pokud by to člověk opravdu z nějakého důvodu chtěl v databázi vidět zvlášť, tak se vždy dají udělat pohledy (VIEW).
    xkucf03 avatar 26.3.2017 15:37 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: MySQL: Rozdělit do tabulek, nebo ne?
    • Data ze všech čidel dej do jedné tabulky.
    • Datum a čas měj v jednom sloupci – typ timestamp – mj. proto, že ti to umožní psát dotazy, které vrací všechny hodnoty mezi dvěma časovými okamžiky (kdybys to měl ve dvou sloupcích, tak ten dotaz bude složitější).
    • Ve druhé tabulce pak budeš mít číselník místností/čidel a mezi tabulkami bude cizí klíč.

    Pro úplnost (ale to teď neřeš):

    • Rozdělit data stejného typu do více tabulek je za běžných okolností chybný návrh, ale někdy se to naopak dělá záměrně kvůli výkonu – říká se tomu partitioning (nebo sharding, když je to distribuované přes víc serverů). Data rozdělíš podle nějakého klíče, např. rok nebo tady místnost – a potom když hledáš záznamy z konkrétního roku nebo místnosti, tak nemusíš prohledávat všechna data (je to ještě rychlejší než indexy). Nicméně tohle by sis neměl implementovat sám v aplikaci a měla by to za tebe řešit databáze nebo nějaký framework.
    • Existují i specializované databáze pro časové řady, ale při tomhle objemu dat to klidně můžeš sypat do té MySQL.
    • Někdy se hodí funkční indexy – ty neindexují hodnotu sloupce ale výsledek nějaké funkce – např. bys mohl zaindexovat funkci, která vrací pouze datum nebo pouze čas nebo den v týdnu atd. a pak si rychle vytáhnout data pro nějaké dny nebo hodiny.
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.