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 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
dnes 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
včera 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

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

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
20.1. 17:00 | Nová verze

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 4
20.1. 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 10
20.1. 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
20.1. 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
20.1. 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
20.1. 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 362 hlasů
 Komentářů: 25, poslední včera 13:34
Rozcestník
Reklama

Dotaz: MySQL databáze

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