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 04:33 | Nová verze

    Linus Torvalds vydal jádro Linux 6.19. Podrobný výčet změn je ke zhlédnutí na stránce Kernel Newbies, stručné výběry v LWN (část první, druhá).

    |🇵🇸 | Komentářů: 0
    včera 03:33 | IT novinky

    Do prodeje jde tichá bezdrátová herní myš Logitech PRO X2 SUPERSTRIKE s analogovými spínači s haptickou odezvou (HITS, Haptic Inductive Trigger System). Cena je 4 459 Kč.

    Ladislav Hagara | Komentářů: 4
    7.2. 21:00 | Zajímavý projekt

    Microsoft na GitHubu zveřejnil zdrojový kód projektu LiteBox, jedná se o 'knihovní operační systém' (library OS) zaměřený na bezpečnost, využívající systémovou architekturu LVBS k ochraně jádra před útoky z uživatelského prostoru. LiteBox je napsán v Rustu a uvolněný pod licencí MIT. Projekt je teprve v rané fázi vývoje.

    NUKE GAZA! 🎆 | Komentářů: 1
    7.2. 16:11 | Zajímavý software

    BreezyBox je open-source shell a virtuální terminál pro populární jednočip ESP32. Nabízí základní unixové příkazy, sledování aktuálního pracovního adresáře (CWD), jednoduchý instalátor a spouštěč aplikací v podobě ELF binárních souborů, zabudovaný HTTP server nebo třeba ovládání WiFi - ukázka použití coby 'malého osobního počítače'. Ačkoliv je BreezyBox inspirovaný BusyBoxem, oproti němu má tento projekt několik externích závislostí, zejména na ESP-IDF SDK. BreezyBox je dostupný pod licencí MIT.

    NUKE GAZA! 🎆 | Komentářů: 0
    7.2. 16:00 | Humor

    Byl představen cross-assembler xa.sh, napsaný čistě v Bourne shell skriptu. Tento nástroj umožňuje zpracovávat assemblerový kód pro Intel 8080, přičemž je možné snadno přidat podporu i pro další architektury, například 6502 a 6809. Skript využívá pouze různé běžné unixové příkazy jako jsou awk, sed nebo printf. Skript si lze stáhnout z GitHubového repozitáře projektu.

    NUKE GAZA! 🎆 | Komentářů: 6
    6.2. 17:22 | IT novinky

    Byla představena nová verze modelu Claude Opus 4.6 od společnosti Anthropic. Jako demonstraci možností Anthropic využil 16 agentů Claude Opus 4.6 k vytvoření kompilátoru jazyka C, napsaného v programovacím jazyce Rust. Claude pracoval téměř autonomně, projekt trval zhruba dva týdny a náklady činily přibližně 20 000 dolarů. Výsledkem je fungující kompilátor o 100 000 řádcích kódu, jehož zdrojový kód je volně dostupný na GitHubu pod licencí Creative Commons.

    NUKE GAZA! 🎆 | Komentářů: 18
    6.2. 16:44 | Komunita

    Kultovní britský seriál The IT Crowd (Ajťáci) oslavil dvacáté výročí svého prvního vysílání. Sitcom o dvou sociálně nemotorných pracovnících a jejich nadřízené zaujal diváky svým humorem a ikonickými hláškami. Seriál, který debutoval v roce 2006, si i po dvou dekádách udržuje silnou fanouškovskou základnu a pravidelně se objevuje v seznamech nejlepších komedií své doby. Nedávné zatčení autora seriálu Grahama Linehana za hatecrime však vyvolává otázku, jestli by tento sitcom v současné Velké Británii vůbec vznikl.

    NUKE GAZA! 🎆 | Komentářů: 10
    6.2. 13:33 | IT novinky

    Společnost JetBrains oznámila, že počínaje verzí 2026.1 budou IDE založená na IntelliJ ve výchozím nastavení používat Wayland.

    Ladislav Hagara | Komentářů: 4
    6.2. 11:22 | IT novinky

    Společnost SpaceX amerického miliardáře Elona Muska podala žádost o vypuštění jednoho milionu satelitů na oběžnou dráhu kolem Země, odkud by pomohly zajistit provoz umělé inteligence (AI) a zároveň šetřily pozemské zdroje. Zatím se ale neví, kdy by se tak mělo stát. V žádosti Federální komisi pro spoje (FCC) se píše, že orbitální datová centra jsou nejúspornějším a energeticky nejúčinnějším způsobem, jak uspokojit rostoucí poptávku po

    … více »
    Ladislav Hagara | Komentářů: 28
    6.2. 11:11 | Nová verze

    Byla vydána nová verze 2.53.0 distribuovaného systému správy verzí Git. Přispělo 70 vývojářů, z toho 21 nových. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (19%)
     (6%)
     (0%)
     (10%)
     (26%)
     (3%)
     (4%)
     (2%)
     (12%)
     (29%)
    Celkem 810 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Filtrování podle štítků - pomohou SQL experti?

    8.9.2008 16:27 | Přečteno: 1607× | AbcLinuxu

    Máme v plánu umožnit filtrování poradny pomocí štítků, což by mělo fungovat jako náhrada za původní strukturu poraden (bug #1091).

    Naše snahy mají ovšem vadu na kráse. Chceme umožnit, aby uživatel mohl zadat podobný filtr:

    (nvidia OR ati) AND ubuntu AND NOT fglrx

    Filtrování může takto fungovat díky štítkům. Potýkáme se ovšem s tím, že vyhledávání trvá příliš dlouho (typicky 5 sekund) a je to velká zátěž na databázi. Našli by se mezi vámi odborníci, kteří by dokázali poradit, jak věc zefektivnit?

    Zde najdete dump databáze (3,2 MB), kde jsou dvě tabulky - relace a stitkovani. U relace je důležité cislo (identifikuje "stránku" v systému, se kterou kód může dále pracovat), potomek nesoucí číslo datové položky v systému, typ_potomka, kde nás zajímají jen relace s hodnotou 'P', a predchozi, pomocí kterého se můžeme omezit na Linuxovou poradnu (číslo 49490).

    V tabulce stitkovani jsou sloupečky typ (opět nás zajímá vždy hodnota 'P'), cislo (které se musí provázat se sloupcem relace.potomek - pozor, ne s relace.cislo!) a stitek obsahující označení samotného štítku.

    Jeden z našich pokusů o vyhledání relací, které splňují podmínku (nvidia OR ati) AND ubuntu, vypadá takto:

    select count(R.cislo) from relace R where R.typ_potomka='P' and
    R.predchozi=49490 and exists (select S.cislo from stitkovani S where S.typ =
    'P' and S.cislo = R.potomek and (S.stitek='nvidia' or S.stitek='ati')) and
    exists (select S.cislo from stitkovani S where S.typ = 'P' and S.cislo =
    R.potomek and S.stitek='ubuntu');

    Vrátí celkem 380 relací za cca 5 sekund, resp. o něco méně při opakování.

           

    Hodnocení: 100 %

            špatnédobré        

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    Komentáře

    Vložit další komentář

    8.9.2008 17:00 janik | blog: janko
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    $ time mysql -u ab ab < orig.sql
    count(R.cislo)
    380

    real 0m1.936s
    user 0m0.011s
    sys 0m0.007s
    $ time mysql -u ab ab < new.sql
    count(R.cislo)
    380

    real 0m0.273s
    user 0m0.012s
    sys 0m0.004s

    SQL prikaz:
    select
        count(R.cislo)
    from
        relace R
        LEFT JOIN stitkovani nvidia ON (nvidia.cislo = R.potomek AND nvidia.stitek='nvidia' AND nvidia.typ = 'P')
        LEFT JOIN stitkovani ati ON (ati.cislo = R.potomek AND ati.stitek='ati' AND ati.typ = 'P')
        LEFT JOIN stitkovani ubuntu ON (ubuntu.cislo = R.potomek AND ubuntu.stitek='ubuntu' AND ubuntu.typ = 'P')
        LEFT JOIN stitkovani fglrx ON (fglrx.cislo = R.potomek AND fglrx.stitek='fglrx' AND fglrx.typ = 'P')
    WHERE
        R.typ_potomka = 'P' AND R.predchozi=49490 AND
        ((nvidia.cislo IS NOT NULL OR ati.cislo IS NOT NULL) AND ubuntu.cislo IS NOT NULL AND NOT fglrx.cislo IS NOT NULL)

    8.9.2008 19:41 Sinuhet | skóre: 31
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?

    A pokud si chceme trochu zaprasit...

    $ time mysql abc_test < new.sql
    count(R.cislo)
    380
    
    real    0m0.558s
    user    0m0.016s
    sys     0m0.004s
    $ time mysql abc_test < q.sql
    count(r.cislo)
    380
    
    real    0m0.187s
    user    0m0.008s
    sys     0m0.004s
    $ cat q.sql
    
    select
            count(r.cislo)
    from
            (
            select
                    s.cislo
            from
                    stitkovani s
            where
                    s.typ = 'P'
                    and s.stitek in ('nvidia', 'ati', 'ubuntu', 'fglrx')
            group by
                    s.cislo
            having
                    bit_or(s.stitek = 'nvidia' or s.stitek = 'ati') = 1
                    and bit_or(s.stitek = 'ubuntu') = 1
                    and bit_or(s.stitek = 'fglrx') = 0
            ) s
            join relace r on (s.cislo = r.potomek)
    where
            r.typ_potomka = 'P'
            and r.predchozi = 49490
    ;
    
    Luboš Doležel (Doli) avatar 8.9.2008 23:45 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    Tak jsem napsal parser vyhledávacích výrazů, který pomůže vygenerovat obdobné SQL. Díky moc, je to dost rychlé :-)
    Josef Kufner avatar 8.9.2008 21:10 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    Místo toho kopce joinů by se dal použít jeden a spočítat, kolik se jich trefilo. Něco jako:
    SELECT R.cislo, COUNT(s.stitek)
    FROM
        relace R
        LEFT JOIN stitkovani s ON (s.cislo = R.potomek AND s.typ = 'P')
    WHERE
        R.typ_potomka = 'P' AND R.predchozi=49490 AND
        s.stitek IN ('ati', 'nvidia', 'ubuntu', 'fglrx')
    GROUP BY R.cislo
    HAVING count(s.stitek) = 4
    
    Nezkoušel jsem to, jen mě to tak napadlo. Ale nenapadá mě, jak do toho zakomponovat ty ostatní operace (or, not).
    Hello world ! Segmentation fault (core dumped)
    Luboš Doležel (Doli) avatar 8.9.2008 21:46 Luboš Doležel (Doli) | skóre: 98 | blog: Doliho blog | Kladensko
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    Něco podobného jsem napsal taky a taky jsem nevěděl, jak zařadit takové operace. Nicméně to, co napsal Sinuhet, vypadá dobře :-)
    Josef Kufner avatar 8.9.2008 22:58 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    Hmm... ono ty operace vlastně ani nejsou moc potřeba, rozhodně ne všechny.

    Když se dotaz převede do tvaru DNF, tak stačí zprovoznit operace A AND B, NOT C a X OR Y, aby se dalo spočítat (A AND B) OR (A AND NOT C). A tohle stačí na vyhodnocení jakéhokoliv výrazu.

    A AND B jsem napsal před chvílí, X OR Y zvládne UNION. Takže zbývá vyřešit operaci NOT C.
    Hello world ! Segmentation fault (core dumped)
    rADOn avatar 8.9.2008 19:00 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    a co na to rika EXPLAIN ? ja bych tipnul ze neco ve smyslu ze ty subselecty jedou fulscanem
    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    8.9.2008 20:10 Leoš Literák | skóre: 74 | blog: LL | Praha
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    To je v linkovane chybe.
    Zakladatel tohoto portálu. Twitter, LinkedIn, blog, StackOverflow
    8.9.2008 19:25 Ignor
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    Tak SQL expert teda opravdu nejsem, což ale mi nebrání k tomu něco říct. Kdybych to dělal já, tak bych jednoznačně měl tabulku stitky, kde by byly... štítky. A do tabulky stitkovani bych strkal místo řetězce odkaz na klíč do tabulky stitky. Nad tím integerem by se navíc dělal index mnohem příjemnějc než nad varchar(30).

    A docela by mě zajímalo jak by to vypadalo, kdyby se použila (první co mě napadne) možnost 'and' dělám 'intersect' a 'or' dělám 'union'.
    9.9.2008 08:14 Michal Vyskočil | skóre: 60 | blog: miblog | Praha
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    No a zrovna od tebe bych čekal spíš, že řekneš, že tohle patří do databázové poradny ;-)
    When your hammer is C++, everything begins to look like a thumb.
    Josef Kufner avatar 8.9.2008 20:58 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    Nezapomeňte na minimalizaci dotazu, který uživatel zadá (pokud to již neděláte).

    ps: Místo hradel si tam představ sql dotaz ;)
    Hello world ! Segmentation fault (core dumped)
    8.9.2008 21:02 depka | skóre: 20 | blog: eterity
    Rozbalit Rozbalit vše Re: Filtrování podle štítků - pomohou SQL experti?
    pouziva vubec nekdo ty stitky?

    Založit nové vláknoNahoru

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.