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 23:33 | Nová verze

    Byla vydána nová verze 25.10.31 svobodného multiplatformního video editoru Shotcut (Wikipedie) postaveného nad multimediálním frameworkem MLT. Shotcut je vedle zdrojových kódů k dispozici také ve formátech AppImage, Flatpak a Snap.

    Ladislav Hagara | Komentářů: 0
    1.11. 07:33 | Komunita

    O víkendu probíhá konference OpenAlt 2025 (Stream). Na programu je spousta zajímavých přednášek. Pokud jste v Brně, stavte se. Vstup zdarma.

    Ladislav Hagara | Komentářů: 0
    1.11. 00:55 | IT novinky

    Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.

    Ladislav Hagara | Komentářů: 7
    31.10. 18:33 | IT novinky

    Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).

    Ladislav Hagara | Komentářů: 0
    31.10. 13:22 | Komunita

    Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).

    Ladislav Hagara | Komentářů: 8
    31.10. 01:22 | Nová verze

    Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    31.10. 00:11 | IT novinky

    Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.

    Ladislav Hagara | Komentářů: 5
    30.10. 23:44 | Komunita

    Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.

    Ladislav Hagara | Komentářů: 0
    30.10. 15:22 | Nová verze

    Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 2
    30.10. 12:55 | Nová verze

    Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).

    Ladislav Hagara | Komentářů: 1
    Jaké řešení používáte k vývoji / práci?
     (36%)
     (48%)
     (19%)
     (18%)
     (22%)
     (16%)
     (20%)
     (16%)
     (17%)
    Celkem 298 hlasů
     Komentářů: 15, poslední včera 08:25
    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: 1352×
    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: 71 | 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: 46 | 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: 71 | 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: 46 | 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.