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 11:33 | Pozvánky

Konference LinuxDays 2017 proběhne o víkendu 7. a 8. října v Praze v Dejvicích v prostorách FIT ČVUT. Konference OpenAlt 2017 proběhne o víkendu 4. a 5. listopadu na FIT VUT v Brně. Organizátoři konferencí vyhlásili CFP (LinuxDays, OpenAlt). Přihlaste svou přednášku nebo doporučte konference známým.

Ladislav Hagara | Komentářů: 0
včera 06:00 | Nová verze

Byla vydána verze 1.3.0 odlehčeného desktopového prostředí Lumina (Wikipedie, GitHub) postaveného nad toolkitem Qt. Z novinek lze zmínit nový motiv ikon nahrazující Oxygen (material-design-[light/dark]) nebo vlastní multimediální přehrávač (lumina-mediaplayer).

Ladislav Hagara | Komentářů: 2
26.6. 17:33 | Bezpečnostní upozornění

Před šesti týdny byly publikovány výsledky bezpečnostního auditu zdrojových kódů OpenVPN a nalezené bezpečnostní chyby byly opraveny ve verzi OpenVPN 2.4.2. Guido Vranken minulý týden oznámil, že v OpenVPN nalezl další čtyři bezpečnostní chyby (CVE-2017-7520, CVE-2017-7521, CVE-2017-7522 a CVE-2017-7508). Nejzávažnější z nich se týká způsobu, jakým aplikace zachází s SSL certifikáty. Vzdálený útočník může pomocí speciálně

… více »
Ladislav Hagara | Komentářů: 1
26.6. 06:55 | Zajímavý projekt

V Edici CZ.NIC vyšla kniha Průvodce labyrintem algoritmů. Kniha je ke stažení zcela zdarma (pdf) nebo lze objednat tištěnou verzi za 339 Kč (připojení přes IPv4) nebo 289 Kč (připojení přes IPv6).

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

Byla vydána verze 2.2.0 svobodného správce hesel KeePassXC (Wikipedie). Jedná se o komunitní fork správce hesel KeePassX s řadou vylepšení.

Ladislav Hagara | Komentářů: 0
26.6. 06:11 | IT novinky

Vývojář Debianu Henrique de Moraes Holschuh upozorňuje v diskusním listu debian-devel na chybu v Hyper-Threadingu v procesorech Skylake a Kaby Lake od Intelu. Za určitých okolností může chyba způsobit nepředvídatelné chování systému. Doporučuje se aktualizace mikrokódu CPU nebo vypnutí Hyper-Threadingu v BIOSu nebo UEFI [reddit].

Ladislav Hagara | Komentářů: 0
24.6. 01:23 | Komunita

Phoronix spustil 2017 Linux Laptop Survey. Tento dotazník s otázkami zaměřenými na parametry ideálního notebooku s Linuxem lze vyplnit do 6. července.

Ladislav Hagara | Komentářů: 3
23.6. 22:44 | Nová verze

Po třech měsících vývoje od vydání verze 5.5.0 byla vydána verze 5.6.0 správce digitálních fotografií digiKam (digiKam Software Collection). Do digiKamu se mimo jiné vrátila HTML galerie a nástroj pro vytváření videa z fotografií. V Bugzille bylo uzavřeno více než 81 záznamů.

Ladislav Hagara | Komentářů: 1
23.6. 17:44 | Nová verze

Byla vydána verze 9.3 open source alternativy GitHubu, tj. softwarového nástroje s webovým rozhraním umožňujícího spolupráci na zdrojových kódech, GitLab. Představení nových vlastností v příspěvku na blogu a na YouTube.

Ladislav Hagara | Komentářů: 3
23.6. 13:53 | Nová verze

Simon Long představil na blogu Raspberry Pi novou verzi 2017-06-21 linuxové distribuce Raspbian určené především pro jednodeskové miniaturní počítače Raspberry Pi. Společně s Raspbianem byl aktualizován také instalační nástroj NOOBS (New Out Of the Box Software). Z novinek lze zdůraznit IDE Thonny pro vývoj v programovacím jazyce Python a především offline verzi Scratche 2.0. Ten bylo dosud možné používat pouze online. Offline bylo možné používat pouze Scratch ve verzi 1.4. Z nového Scratchu lze ovládat také GPIO piny. Scratch 2.0 vyžaduje Flash.

Ladislav Hagara | Komentářů: 2
Chystáte se pořídit CPU AMD Ryzen?
 (6%)
 (31%)
 (1%)
 (9%)
 (44%)
 (9%)
Celkem 853 hlasů
 Komentářů: 65, poslední 1.6. 19:16
    Rozcestník

    Dotaz: Mysql vyber z vice tabulek.

    26.2.2009 14:33 Petr
    Mysql vyber z vice tabulek.
    Přečteno: 1344×

    Zdravim.

    Mam nasledujici problem. Mam ulozeny IP adresy v 5 tabulkach. Potreboval bych pomoci SQL dotazu vybrat vsechny IP adresy ze vsech tabulek, "zgrupovat" duplicitni zaznamy a zaroven spocitat, kolikrat se ktera IP adresa ve vsech tabulkach nachazela. Pro jednu tabulku jsem to resil naledovne - "SELECT IP, COUNT(*) as Pocet FROM tabulka GROUP BY IP", ale pro vice tabulek jsem bezradny.

    dekuji za pomoc Petr

    btw. "nalit" vsechny data do jedne tabulky se mi nechce, protoze v kazde tabulce je cca 0,5 mil zaznamu.

    Odpovědi

    the.max avatar 26.2.2009 15:14 the.max | skóre: 46 | blog: Davidovo smetiště | Bílina
    Rozbalit Rozbalit vše Re: Mysql vyber z vice tabulek.
    mozna ti pomuze tohle.
    KERNEL ULTRAS Fan Team || Sabaton - nejlepší učitel dějepisu
    26.2.2009 15:47 Petr
    Rozbalit Rozbalit vše Re: Mysql vyber z vice tabulek.

    Diky, toto mi bohuzel nepomohlo - neslo o JOIN ale o UNION (kde je ale problem s funkci COUNT)

    Vyresil jsem to tak, ze jsem vytvoril view do ktereho jsem vybral IP adresy ze vsech tabulek (pomoci UNION ALL) a nasledny COUNT a GROUP BY jsem udelal nad timto view.

    Pokud by se nekomu podarilo nacpat vse do "jednoho" SQL dotazu, tak pro zajimovost prosim o zaslani. Alespon bych udelal benchmark co je rychlejsi :-)

    default avatar 27.2.2009 22:05 default | skóre: 22 | Madrid
    Rozbalit Rozbalit vše Re: Mysql vyber z vice tabulek.
    Příloha:

    Neznám strukturu tabulek, ale napadá mě toto:

    SELECT
        ip_address,
        COUNT(1)
    FROM
        (SELECT
            ip AS ip_address
        FROM
            ip1
        UNION ALL
        SELECT
            ip
        FROM
            ip2)
    GROUP BY
        ip_address
    /
    

    Pokud tě zajímají hlubší statistiky, například groupovat i po tabulkách (postupné součty), jde to udělat takto:

    SELECT
        ip_address,
        table_type,
        COUNT(1)
    FROM
        (SELECT
            ip AS ip_address,
            1 AS table_type
        FROM
            ip1
        UNION ALL
        SELECT
            ip,
            2
        FROM
            ip2)
    GROUP BY
        ip_address,
        table_type
    /
    

    Postupné součty:

    SELECT
        table_type,
        ip_address,
        COUNT(1)
    FROM
        (SELECT
            ip AS ip_address,
            1 AS table_type
        FROM
            ip1
        UNION ALL
        SELECT
            ip,
            2
        FROM
            ip2)
    GROUP BY ROLLUP (
        table_type,
        ip_address)
    /
    

    Na databázích, které nepodporují GROUP BY ROLLUP, se to musí trošku vochcat:

    SELECT
        table_type,
        ip_address,
        COUNT(1)
    FROM
        (SELECT ip AS ip_address, 1 AS table_type FROM ip1
        UNION ALL
        SELECT ip,                2               FROM ip2)
    GROUP BY
        table_type,
        ip_address
    UNION ALL
    SELECT
        table_type,
        NULL,
        COUNT(1)
    FROM
        (SELECT ip AS ip_address, 1 AS table_type FROM ip1
        UNION ALL
        SELECT ip,                2               FROM ip2)
    GROUP BY
        table_type
    UNION ALL
    SELECT
        NULL,
        NULL,
        COUNT(1)
    FROM
        (SELECT ip AS ip_address, 1 AS table_type FROM ip1
        UNION ALL
        SELECT ip,                2               FROM ip2)
    /
    

    Z toho je vidět, že se musí ty tabulky probrousit několikrát, což není dvakrát cool. Ale naštěstí Oracle i DB2 je v klidu. :-D

    Co se výkonu týče, byl bych úplně vklidu. Zrovna dneska jsem třeba dopsal SELECT, který brousí tabulky s několika miliony záznamů. Je to celkem zajímavý report, tak mě to bavilo. :-D A výsledková sada je u klienta do 30 sekund. Ani jsem neřešil indexy :-D protože by to stejně při tak malém množství vyšlo na FULL SCAN. :-D

    Dobrá, tak vážně. Pokud s datovou strukturou nemůžeš pohnout, zajímal bych se o materializované pohledy. Jak jsem to pochopil, spíš se u tebe jedná o nějaké logy, takže spíš pod tlakem smažíš nové záznamy. Materializovaný pohled umí být FAST REFRESH ON COMMIT, což by mělo jít na MySQL nějak očurat (ano, fackuju se) triggerem. Kdyžtak kdykoli můžeš ty logy odlejt někam do historie, udělat z nich agregát a k němu pak připočítávat (tabulka IP_AVG obsahuje ten agregát tabulky IP1) (sakra, já jsem dneska nějakej dobrej; asi bych toho měl už nechat…):

    SELECT
        NVL(x.ip, y.ip) AS ip,
        NVL(x.cnt, 0) + NVL(y.cnt, 0) AS cnt
    FROM
        (SELECT
            ip,
            COUNT(1) AS cnt
        FROM
            ip2
        GROUP BY
            ip) x
        FULL OUTER JOIN
        (SELECT
            ip,
            cnt
        FROM
            ip_avg) y
        ON (x.ip = y.ip)
    /
    

    Až na ten FULL OUTER JOIN se mi to líbí. :-D A ten jde obejít takto:

    SELECT
        ip,
        SUM(cnt)
    FROM
        (SELECT
            ip,
            COUNT(1) AS cnt
        FROM
            ip2
        GROUP BY
            ip
        UNION ALL
        SELECT
            ip,
            cnt
        FROM
            ip_avg)
    GROUP BY
        ip
    /
    

    Jo. A místo NVL() jde použít NULLIF(). :-)

    A mimochodem: díky za zpříjemnění večera. Už jsem se bál, že se budu nudit. :-D :-D :-D

    P.S.: Jako obvykle: v příloze je skript na hraní; tak hodně štěstí!

    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.