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 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    24.12. 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 22
    24.12. 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    Kdo vám letos nadělí dárek?
     (34%)
     (2%)
     (10%)
     (2%)
     (1%)
     (2%)
     (16%)
     (19%)
     (13%)
    Celkem 89 hlasů
     Komentářů: 18, poslední 24.12. 15:30
    Rozcestník

    Dotaz: MySQL databáze

    30.7.2013 00:14 Pavel | skóre: 17
    MySQL databáze
    Přečteno: 955×
    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.