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 11:00 | Komunita

Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už zítra 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.

xkucf03 | Komentářů: 0
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ářů: 3
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ářů: 2
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
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 309 hlasů
 Komentářů: 24, poslední včera 10:14
    Rozcestník
    Reklama

    Dotaz: slouceni dvou dotazu

    25.11.2009 07:51 Leoš Literák | skóre: 74 | blog: LL | Praha
    slouceni dvou dotazu
    Přečteno: 599×
    Ahoj, mam dalsi dotaz pro vyvoj abicka, holt sql neni moje parketa. Mam dva dotazy, ktere samostatne funguji. Chtel bych to zoptimalizovat, abych je nemusel spoustet a zpracovavat samostatne, ale mel jen jeden dotaz se dvema hodnotovymi sloupecky. Lisi se jen jednou podminkou rovnosti S.pridal,RS.kdo a obsahuji count a group by. Databaze mysql.
    select K.autor,count(*) from komentar K, reseni RS, relace R, spolecne S where 
    RS.zaznam=R.potomek and R.typ_potomka='Z' and R.predek=S.cislo and S.typ='P' and 
    (S.pridal<>RS.kdo or S.pridal is null) and K.cislo=RS.komentar and RS.kdo<>K.autor group by K.autor
    | autor | count(*) |
    +-------+----------+
    |     1 |        1 |
    |    11 |        1 |
    |    20 |        2 |
    |   151 |        4 |
    |   595 |        2 |
    select K.autor,count(*) from komentar K, reseni RS, relace R, spolecne S where 
    RS.zaznam=R.potomek and R.typ_potomka='Z' and R.predek=S.cislo and S.typ='P' and 
    S.pridal=RS.kdo and K.cislo=RS.komentar and RS.kdo<>K.autor group by K.autor
    | autor | count(*) |
    +-------+----------+
    |     1 |        3 |
    |   151 |        2 |
    |   421 |        1 |
    |   595 |        2 |
    |   868 |        1 |
    Chtel bych dostat takovyto vysledek:
    | autor | count(*) | count(*) |
    +-------+----------+----------+
    |     1 |        3 |        1 |
    |   151 |        2 |        4 |
    |   421 |        1 |        0 |
    |   595 |        2 |        2 |
    |   868 |        1 |        3 |
    Diky
    Zakladatel tohoto portálu. Twitter, LinkedIn, blog, StackOverflow

    Řešení dotazu:


    Odpovědi

    25.11.2009 08:32 kulik
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    Myslim ze by melo jit ty lisici se podminky vytahnout do agregace. Nevim jak se to udela v mysql, ale v Oracle by to mohlo vypadat takto (lepsi nez decode je case, ale pravdepodobnost vyskytu jeho analogie v mysql vidim jako mensi):
    select K.autor,        
           sum(decode(S.pridal, null, 1, RS.kdo, 0, 1)) cnt1,
           sum(decode(S.pridal, null, 0, RS.kdo, 1, 0)) cnt2       
    from komentar K, reseni RS, relace R, spolecne S 
    where 
    RS.zaznam=R.potomek and R.typ_potomka='Z' and R.predek=S.cislo and S.typ='P' and K.cislo=RS.komentar and RS.kdo<>K.autor group by K.autor
    

    25.11.2009 16:52 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    +1 aj s CASE :-) +10 za verziu s triggrami.
    25.11.2009 20:24 Leoš Literák | skóre: 74 | blog: LL | Praha
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    decode mysql nema, case ano. Tento prikaz skonci chybou. Jak by to vypadalo s case? Dik
    Zakladatel tohoto portálu. Twitter, LinkedIn, blog, StackOverflow
    25.11.2009 10:07 posejdon
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    myslim, ze mysql 5 a vyssi by si melo poradit s timto, nicmene reseni navrzene vyse by melo byt optimalnejsi (jedinny pruchod tabulky), mysql pouziti CASE umoznuje a v tomto pripade by mohlo zvysit prehlednost kodu (resp umysl bude bit do oci na 1. pohled).

    select t1.autor, t1.c1, t2.c2

    FROM

    (select K.autor,count(*) as c1 from komentar K, reseni RS, relace R, spolecne S where

    RS.zaznam=R.potomek and R.typ_potomka='Z' and R.predek=S.cislo and S.typ='P' and

    (S.pridal<>RS.kdo or S.pridal is null) and K.cislo=RS.komentar and RS.kdo<>K.autor group by K.autor) t1

    JOIN

    (select K.autor,count(*) as c2 from komentar K, reseni RS, relace R, spolecne S where

    RS.zaznam=R.potomek and R.typ_potomka='Z' and R.predek=S.cislo and S.typ='P' and

    S.pridal=RS.kdo and K.cislo=RS.komentar and RS.kdo<>K.autor group by K.autor) t2

    ON t2.autor = t1.autor
    25.11.2009 20:27 Leoš Literák | skóre: 74 | blog: LL | Praha
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    Dik, tohle funguje, explain ukazuje deset tabulek. Zatim je tam malo dat, takze rychlost neni prekazkou. Jsem perfekcionista, zajimala by me ta varianta s case.
    Zakladatel tohoto portálu. Twitter, LinkedIn, blog, StackOverflow
    25.11.2009 22:28 posejdon
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    No myslel jsem, ze nakopnuti od kolegy a dokumentace k MySQL postaci, ale zkusim nazorny priklad, vzdyt je to pro dobrou vec (a zvladnou to i prehistoricke vydani MySQL)
    select K.autor,
           sum( CASE WHEN S.pridal=RS.kdo and K.cislo=RS.komentar THEN 1 ELSE 0 END ) cnt1,
           sum( CASE WHEN S.pridal<>RS.kdo or S.pridal is null THEN 1 ELSE 0 END ) cnt2
    from komentar K, reseni RS, relace R, spolecne S 
    where RS.zaznam=R.potomek 
     and R.typ_potomka='Z' 
     and R.predek=S.cislo 
     and S.typ='P' 
     and K.cislo=RS.komentar 
     and RS.kdo<>K.autor 
    group by K.autor
    
    Řešení 1× (Leoš Literák (tazatel))
    25.11.2009 22:55 posejdon
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    Jeste bych se chtel primluvit za to, abys pouzival ke spojovani tabulek JOIN namisto kartezskeho soucinu omezeneho v klauzuli where, nebot se celkem spatne hleda, co je spojeno s cim (ale na rychlost dotazu to nema vliv a je to spise o zvyku, ja takto rovnou vidim relaci a nemusim to hledat v podminkach)
    SELECT K.autor,
           SUM( CASE WHEN S.pridal = RS.kdo AND K.cislo = RS.komentar THEN 1 ELSE 0 END ) cnt1,
           SUM( CASE WHEN S.pridal <> RS.kdo OR S.pridal IS NULL THEN 1 ELSE 0 END ) cnt2
    FROM komentar K
    JOIN reseni RS ON RS.komentar = K.cislo
    JOIN relace R ON R.potomek = RS.zaznam 
                  AND R.typ_potomka='Z'
    JOIN spolecne S ON s.cislo = r.predek
                    AND S.typ='P' 
    WHERE RS.kdo <> K.autor 
    GROUP BY K.autor
    
    26.11.2009 06:16 Leoš Literák | skóre: 74 | blog: LL | Praha
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    Ahoj, mozna by stacila, ale nemel jsem klid na praci (dve deti) a hlavne bych musel zjistit, k cemu ten oracle decode vlastne slouzi. Pak bych mel sanci. Kazdopadne dekuju, funguje to, druhy priklad uz v explain ma jen ctyri tabulky pouzivajici klice.

    Pokud jde o ty joiny, souhlasim, ze jejich pouziti cini dotazy citelnejsi. Maji jeste nejake dalsi vyhody oproti ekvivalentnim dotazum s podminkami ve where? Treba lepsi vykon? Pak by melo smysl prepsat vsechny SQL dotazy.
    Zakladatel tohoto portálu. Twitter, LinkedIn, blog, StackOverflow
    26.11.2009 09:12 kulik
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    Vykon by mel byt stejny, jde jen o ruznou formu zapisu tehoz. Ale samozrejme nelze nikdy uplne vyloucit, ze konkretni stroj se k tomu postavi ruzne, treba kvuli nejakemu bugu apod.
    26.11.2009 09:52 posejdon
    Rozbalit Rozbalit vše Re: slouceni dvou dotazu
    Jde o to, jestli se v tom hrabes sam, nebo to ma nekdy nekdo po tobe louskat. A taky jde o ten zvyk. Znam nektere matadory, kteri join nepouzivaji, ale na druhou stranu si pomahaji treba tim, ze ty relacni podminky davaji na prvni misto a jeste je odlisuji od ostatnich tim, ze je pisi cele kapitalkama. Takovy dotaz se uz cte lip, nicmene ten JOIN navic hlida kodera, aby nezapomnel tu vazbu uvest, coz se treba pri spojeni 10 tabulek stane raz dva.

    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.