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 21:55 | Komunita

Nadace pro svobodný software (FSF) oznámila aktualizaci seznamu prioritních oblastí (changelog), na které by se měli vývojáři a příznivci svobodného softwaru zaměřit. Jsou to například svobodný operační systém pro chytré telefony, hlasová a video komunikace nebo softwarový inteligentní osobní asistent.

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

Byla vydána verze 2.0.0 knihovny pro vykreslování grafů v programovacím jazyce Python Matplotlib (Wikipedie, GitHub). Přehled novinek a galerie grafů na stránkách projektu.

Ladislav Hagara | Komentářů: 0
včera 15:33 | Komunita

V australském Hobartu probíhá tento týden konference linux.conf.au 2017. Na programu je celá řada zajímavých přednášek. Sledovat je lze online.

Ladislav Hagara | Komentářů: 0
včera 10:20 | Zajímavý článek

Pavel Tišnovský se v dvoudílném článku na MojeFedora.cz věnuje bitmapovým (rastrovým) grafickým editorům ve Fedoře. V prvním dílu se věnuje editorům MyPaint, MtPaint, Pinta, XPaint, Krita a GIMP. V pokračování pak editorům GNU Paint (gpaint), GrafX2, KolourPaint, KIconEdit a Tux Paint.

Ladislav Hagara | Komentářů: 1
16.1. 17:11 | Komunita

Byl proveden bezpečnostní audit svobodného IMAP a POP3 serveru Dovecot (Wikipedie). Audit byl zaplacen z programu Mozilla Secure Open Source a provedla jej společnost Cure53. Společnost Cure53 byla velice spokojena s kvalitou zdrojových kódu. V závěrečné zprávě (pdf) jsou zmíněny pouze 3 drobné a v upstreamu již opravené bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
16.1. 15:30 | IT novinky

Nadace Raspberry Pi představila na svém blogu Raspberry Pi Compute Module 3 (CM3 a CM3L), tj. zmenšené Raspberry Pi vhodné nejenom pro průmyslové využití. Jedná se o nástupce Raspberry Pi Compute Module (CM1) představeného v dubnu 2014. Nový CM3 vychází z Raspberry Pi 3 a má tedy dvakrát více paměti a desetkrát větší výkon než CM1. Verze CM3L (Lite) je dodávána bez 4 GB eMMC flash paměti. Uživatel si může připojit svou vlastní. Představena byla

… více »
Ladislav Hagara | Komentářů: 1
16.1. 01:23 | Nová verze

Oficiálně bylo oznámeno vydání verze 3.0 multiplatformního balíku svobodných kancelářských a grafických aplikací Calligra (Wikipedie). Větev 3 je postavena na KDE Frameworks 5 a Qt 5. Krita se osamostatnila. Z balíku byly dále odstraněny aplikace Author, Brainstorm, Flow a Stage. U Flow a Stage se předpokládá jejich návrat v některé z budoucích verzí Calligry.

Ladislav Hagara | Komentářů: 7
15.1. 15:25 | Nová verze

Bylo oznámeno vydání první RC (release candidate) verze instalátoru pro Debian 9 s kódovým názvem Stretch. Odloženo bylo sloučení /usr jako výchozí nastavení v debootstrap. Vydán byl také Debian 8.7, tj. sedmá opravná verze Debianu 8 s kódovým názvem Jessie.

Ladislav Hagara | Komentářů: 6
15.1. 13:37 | Zajímavý projekt

1. ledna byl představen projekt Liri (GitHub). Jedná se o spojení projektů Hawaii, Papyros a původního projektu Liri s cílem vyvíjet operační systém (linuxovou distribuci) a aplikace s moderním designem a funkcemi. Včera byl představen Fluid 0.9.0 a také Vibe 0.9.0. Jedná se o toolkit a knihovnu pro vývoj multiplatformních a responzivních aplikací podporující Material Design (Wikipedie) a volitelně také Microsoft Design Language (designový jazyk Microsoft) [reddit].

Ladislav Hagara | Komentářů: 8
14.1. 00:33 | Zajímavý software

Google na svém blogu věnovaném open source představil knihovnu pro komprimaci a dekomprimaci 3D grafiky s názvem Draco. Knihovna bude využívána například v aplikacích pro virtuální a rozšířenou realitu. Porovnání Draco s gzip na YouTube. Zdrojové kódy Draco jsou k dispozici na GitHubu pod licencí Apache 2.0.

Ladislav Hagara | Komentářů: 5
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (75%)
 (3%)
 (10%)
Celkem 304 hlasů
 Komentářů: 24, poslední včera 10:14
    Rozcestník
    Reklama

    Dotaz: MySQL a PHP - jak jsou rychlé poddotazy

    13.1.2009 19:23 tobik | skóre: 13
    MySQL a PHP - jak jsou rychlé poddotazy
    Přečteno: 729×

    Mám následující situaci: tabulka s článkama, každý článek má id (primary key, auto_increment) a je zařazen do seriálu (sloupec serie). Mám vybraný článek, jeho id a id seriálu, do kterého je zařazen. A nyní potřebuju vypsat z databáze řekněme 2 články před a 2 články po daném článku včetně daného ze seriálu. Celkem 5, přičemž pokud bude vybraný článek první či poslední, budou vypsané jen 3, logicky. Něco podobného má třeba root.cz.

    Sesmolil jsem následující SQL dotaz, který to udělá:

    SELECT id, time, title,
    (SELECT COUNT(*) FROM articles as pocitadlo WHERE serie=$serie_id AND articles.id>=pocitadlo.id) as poradi
    FROM articles as articles
    WHERE serie=$serie_id
    HAVING poradi<=(SELECT COUNT(*) FROM articles as pocitadlo WHERE pocitadlo.id<=$article_id AND serie=$serie_id)+2 AND
    poradi>=(SELECT COUNT(*) FROM articles as pocitadlo WHERE pocitadlo.id<=$article_id AND serie=$serie_id)-2
    ORDER BY poradi ASC

    Pokud jste si všimli, tak pro každý článek ze seriálu se vykoná poddotaz. Tedy pro n řádků n poddotazů (v praxi se bude počet pohybovat kolem 10-20). Jelikož nerozumím databázím zevnitř, jak jsou optimalizované, tak by mě zajímalo, jestli by nebylo třeba výkonově výhodnější vypsat jednoduchým dotazem všechny články seriálu a zbytek dopočítat pomocí PHP.

    Samozřejmě uvítám, pokud někdo přijde s elegantnějším řešením:-)

    Odpovědi

    Josef Kufner avatar 13.1.2009 20:01 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: MySQL a PHP - jak jsou rychlé poddotazy
    Koukni se k cemu slouzi LIMIT a jak funguje.

    Cislovani radku vysledku pak případně dělej až v aplikaci při načítání výsledku (ale obvykle to není potřeba a pokud chceš identifikovat řádek, je lepší tam nechat ID).
    Hello world ! Segmentation fault (core dumped)
    Josef Kufner avatar 13.1.2009 20:13 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: MySQL a PHP - jak jsou rychlé poddotazy
    Aha, jsem to nečetl moc pozorně...

    Zkus to buď rozdělit na dva jednoduché selecty, kde jeden vrátí předchozí a druhý následující:
    SELECT a.*
    FROM articles a
    WHERE a.date >= (SELECT c.date WHERE c.id = $article_id)
       AND a.serie = $serie
    ORDER BY a.date ASC
    LIMIT 2
    
    SELECT a.*
    FROM articles a
    WHERE a.date < (SELECT c.date WHERE c.id = $article_id)
       AND a.serie = $serie
    ORDER BY a.date DESC
    LIMIT 2
    
    Nebo mít díly očíslované (sloupeček s pořadovým číslem dílu v seriálu) a pak použít jednoduchý (i když trošku neobvyklý) join:
    SELECT a.*
    FROM articles a, articles c
    WHERE a.serie = $serie AND c.id = $article_id
       AND (a.poradi BETWEEN c.poradi - 2 AND c.poradi + 2)
    
    Hello world ! Segmentation fault (core dumped)
    13.1.2009 21:05 tobik | skóre: 13
    Rozbalit Rozbalit vše Re: MySQL a PHP - jak jsou rychlé poddotazy

    Jasně, limitem to nejde, jinak bych se neptal:-).

    Obojí řešení jsou použitelná a obojí jsem zvažoval. Obecně by mě zajímalo, zda je lepší psát složitější příkazy a provádět je najednou a nebo je dělit na jednodušší a provádět zvlášť. Dosud jsem se snažil omezovat počet přístupů k SQL co nejméně (i proto, že výsledný php kód je pak přehlednější), proto jsem udělal tu dlouhou verzi. Samozřejmě, pokud těch článků bude hodně, tak se vyplatí ty dva, ale co je hodně? 10, 100 nebo 1000 řádků? To je jedna z věcí, která by mě zajímala.

    Jinak druhý způsob by znamenal změnit zapisování článků do databáze. Při každém přesunu článku či smazání by se muselo pořadí přepočítávat, což mi přišlo zbytečně komplikované.

    Josef Kufner avatar 14.1.2009 01:12 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: MySQL a PHP - jak jsou rychlé poddotazy
    Ono je nejlepší si na to pustit explain a kouknout se. To co tam máš ty znamená spustit subselect pro každý řádek. Ten můj se spustí jen jednou pro celý dotaz (nezávisí to na řádku, je to konstanta).

    Složitější příkazy se občas vyplatí a občas ne. Něco je lepší udělat nadvakrát pomocí triviálních dotazů než vyrábět cosi komplikovaného. Jiné věci se vyplatí poskládat v DB, protože by se to jinde skládalo těžko.

    Taky je potřeba brát v úvahu kešování -- pokud se část složitého dotazu mění a část je stále stejná, vyplatí se to rozdělit a umožnit tak kešování aspoň části dotazu. Pokud máš složité joiny nad spoustou dat a použiješ LIMIT, vyplatí se LIMIT schovat do subselectu a joinovat k olimitovanému mezivýsledku. Atd, atd,... Úspory po takovýchto úpravách jsou i ve stovkách procent.

    Přepočítávání při přesunu sice je trošku složitější, ale ušetří práci při zobrazování, což je daleko častější operace.
    Hello world ! Segmentation fault (core dumped)
    14.1.2009 10:00 tobik | skóre: 13
    Rozbalit Rozbalit vše Re: MySQL a PHP - jak jsou rychlé poddotazy

    Explain zkusím, děkuji za tip.

    Zajímalo by mě, kolik času (procentuálně) zabere volání dotazu pomocí php. Pokud by odeslání dotazu zabralo řekněme 80% času a samotné vykonání v mysql jen 20%, tak by se do určité míry vyplatilo používat spíš poddotazy, než volat 2x mysql_query.

    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.