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í
×
    dnes 04:44 | Komunita

    Ubuntu 26.10 bude Stonking Stingray (úžasný rejnok).

    Ladislav Hagara | Komentářů: 1
    včera 22:22 | Nová verze

    Webový prohlížeč Dillo (Wikipedie) byl vydán ve verzi 3.3.0. S experimentální podporou FLTK 1.4. S příkazem dilloc pro ovládání prohlížeče z příkazové řádky. Vývoj prohlížeče se přesunul z GitHubu na vlastní doménu dillo-browser.org (Git).

    Ladislav Hagara | Komentářů: 1
    včera 21:55 | Komunita

    Byl publikován přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Vývojáři v přehledu vypíchli vylepšenou instalaci, podporu senzoru okolního světla, úsporu energie, opravy Bluetooth nebo zlepšení audia. Vývoj lze podpořit na Open Collective a GitHub Sponsors.

    Ladislav Hagara | Komentářů: 0
    25.4. 04:00 | Nová verze

    raylib (Wikipedie), tj. multiplatformní open-source knihovna pro vývoj grafických aplikací a her, byla vydána ve verzi 6.0.

    Ladislav Hagara | Komentářů: 0
    24.4. 18:33 | IT novinky

    Nové verze AI modelů. Společnost OpenAI představila GPT‑5.5. Společnost DeepSeek představila DeepSeek V4.

    Ladislav Hagara | Komentářů: 0
    24.4. 15:33 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 164 (pdf) a Hello World 29 (pdf).

    Ladislav Hagara | Komentářů: 0
    24.4. 04:44 | Komunita

    Bylo oznámeno, že webový prohlížeč Opera GX zaměřený na hráče počítačových her je už také na Flathubu and Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    23.4. 23:11 | IT novinky

    Akcionáři americké mediální společnosti Warner Bros. Discovery dnes schválili převzetí firmy konkurentem Paramount Skydance za zhruba 110 miliard dolarů (téměř 2,3 bilionu Kč). Firmy se na spojení dohodly v únoru. O část společnosti Warner Bros. Discovery dříve usilovala rovněž streamovací platforma Netflix, se svou nabídkou však neuspěla. Transakci ještě budou schvalovat regulační orgány, a to nejen ve Spojených státech, ale také

    … více »
    Ladislav Hagara | Komentářů: 0
    23.4. 22:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 26.04 LTS Resolute Raccoon. Přehled novinek v poznámkách k vydání. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 11. vydání s dlouhodobou podporou (LTS).

    Ladislav Hagara | Komentářů: 2
    23.4. 11:55 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Gitea (Wikipedie) byla vydána v nové verzi 1.26.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (4%)
     (7%)
     (2%)
     (15%)
     (25%)
    Celkem 1428 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: MySQL databáze

    30.7.2013 00:14 Pavel | skóre: 17
    MySQL databáze
    Přečteno: 958×
    Zdravím, mám vytvořenou databázi v MySQL, do které ukládám data ze stránek PHP sciptem. Čas od času (cca 1x denně) bych potřeboval řádky v tabulce projet, 30 z nich vybrat a ty uložit do jiné tabulky. V čem je nejlepší takovýto program napsat? Zkušenosti mam s c/c++ ale jen pod windows. Ale nedokážu si představit jak přistupuju k databázi. Měl bych ještě jednu otázku: Jsou databáze uloženy jen na disku a tedy každý přístup do ní znamená činnost disku? Jestli ano, co takhle zrcadlení do RAM pro čtení databáze?

    Řešení dotazu:


    Odpovědi

    30.7.2013 00:33 Kit
    Rozbalit Rozbalit vše Re: MySQL databáze
    Nejlépe bude, když to napíšeš také v PHP. Je to vlastně jen zavolání jednoho SQL dotazu, v PHP nebude skoro nic navíc.

    Databáze MySQL sice sídlí na disku, ale v RAM si sama vytváří cache, která s přístupy na disk šetří jak umí. Zrcadlení do RAM je zpravidla zbytečné.
    30.7.2013 01:00 Pavel | skóre: 17
    Rozbalit Rozbalit vše Re: MySQL databáze
    Pokud to budu dělat v PHP tak budu muset vyřešit aby se ten program spustil každý den pouze jednou. Jinak ta stránka v PHP se bude volat z klienta v rozmezí 5-60 vteřin, takže nemůžu naplánovat aby to přesně v 0:00 provedlo kopírování. Jak by pak vypadl SQL dotaz? Otevření první tabulky, SELECTem vybrat co chci, zkopírovat do pole, uložit do druhé tabulky?
    Řešení 1× (rADOn)
    30.7.2013 01:28 Kit
    Rozbalit Rozbalit vše Re: MySQL databáze
    Spouštění vyřešíš cronem.

    Ten SQL dotaz by mohl vypadat například takto:
    INSERT INTO tab2 (pole1, pole2)
       SELECT aa1, aa2 FROM tab1
          ORDER BY datum DESC LIMIT 3O;
    Kopírování do pole nedoporučuji, zbytečně by to prodloužilo dobu zpracování.
    30.7.2013 02:58 Pavel | skóre: 17
    Rozbalit Rozbalit vše Re: MySQL databáze
    takle by to bylo v případě že chci posledních 30 hodnot, ale pokad budu mít 16 sloupců(čas, hodnota1, hodnota2,...hodnota15) a budu chtít třeba za posledních 24hodin najít v každém sloupci minimum a maximum a tuto hodnotu uložit společně s časem do druhé tabulky, tak už pole použít musim, abych to projel ne? Jak by pak měl vypadat formát druhé tabulky? Momentálně má 3 sloupce. První obsahuje hodnota1min, hodnota1max, hodnota2min,hodnota2max,... a slouží pouze jen k přehlednosti, ve druhém jsou hodnoty a ve třetím sloupci čas.
    30.7.2013 09:00 Kit
    Rozbalit Rozbalit vše Re: MySQL databáze
    ...řádky v tabulce projet, 30 z nich vybrat a ty uložit do jiné tabulky...
    Samozřejmě čím víc normalizačních pravidel ta první tabulka porušuje, tím bude SQL dotaz složitější.
    30.7.2013 11:42 Karlos
    Rozbalit Rozbalit vše Re: MySQL databáze
    Tabulku bych novou nedělal. vytvořil bych si jeden dotaz (přes group by nad date, vyhledat min a max) a aplikoval na původní. Buď se dá vytvořit view, nebo se ten dotaz nechá generovat v php podle naklikaných předvoleb (nebo obojí). Pokud se nejedná o tisíce řádků za den, tak to problém nebude.
    rADOn avatar 30.7.2013 16:40 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: MySQL databáze
    mysql dbname <<EOF
    INSERT INTO table2 (hodnota1_max)
    SELECT max(hodnota1) FROM table1
    WHERE … ;
    
    INSERT INTO table2 (hodnota2_max)
    SELECT max(hodnota2) FROM table1
    WHERE … ;
    
    …
    EOF
    
    Napises do shellskriptu, pustis z cronu. php netreba. sql nema pole ve smyslu php, ale to neznamena ze neumi pracovat s mnozinami hodnot. Pokud to pujde, drz se holeho sql, byt je to syntakticky obcas dost pres ruku. Vetsina slozitejsich veci by sla napsat v shellu, coz bude z hlediska cronu porad jeste "nativni" a snaze laditelne. Na opravdu komplikovane ulohy se obvykle pouziva perl, python, ruby nebo nejaky jiny univerzalni skriptovaci jazyk. Phpcko ne, to je jazyk na delani webu a vsude jinde spis prekazi. C/C++ taky ne, to je na zasadni veci kde potrebujes maximalni vykon a pocitas kazdou mikrosekundu.

    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    rADOn avatar 30.7.2013 16:50 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: MySQL databáze
    … Měl bych ještě jednu otázku: Jsou databáze uloženy jen na disku a tedy každý přístup do ní znamená činnost disku? Jestli ano, co takhle zrcadlení do RAM pro čtení databáze?
    Nevrtej do toho. Databaze maji spoustu vlastnich vyrovnavacich pameti, system take, a narozdil od tebe pri jejich pouzivani dbaji na transakcni izolaci a konzistenci dat. Jestli mas problem s vykonem a prebytky pameti, tak polad velikost buffer poolu a query cache.
    "2^24 comments ought to be enough for anyone" -- CmdrTaco

    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.