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 07:33 | Komunita

    O víkendu probíhá konference OpenAlt 2025. Na programu je spousta zajímavých přednášek. Pokud jste v Brně, stavte se. Vstup zdarma.

    Ladislav Hagara | Komentářů: 0
    dnes 00:55 | IT novinky

    Josef Průša představil novou velkoformátovou uzavřenou CoreXY 3D tiskárnu Prusa CORE One L a nový open source standard chytrých cívek OpenPrintTag i s novou přepracovanou špulkou.

    Ladislav Hagara | Komentářů: 2
    včera 18:33 | IT novinky

    Na GOG.com běží Autumn Sale. Při té příležitosti je zdarma hororová počítačová hra STASIS (ProtonDB: Platinum).

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Komunita

    Ubuntu 25.10 má nově balíčky sestavené také pro úroveň mikroarchitektury x86-64-v3 (amd64v3).

    Ladislav Hagara | Komentářů: 6
    včera 01:22 | Nová verze

    Byla vydána verze 1.91.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    včera 00:11 | IT novinky

    Ministerstvo průmyslu a obchodu vyhlásilo druhou veřejnou soutěž v programu TWIST, který podporuje výzkum, vývoj a využití umělé inteligence v podnikání. Firmy mohou získat až 30 milionů korun na jeden projekt zaměřený na nové produkty či inovaci podnikových procesů. Návrhy projektů lze podávat od 31. října do 17. prosince 2025. Celková alokace výzvy činí 800 milionů korun.

    Ladislav Hagara | Komentářů: 5
    30.10. 23:44 | Komunita

    Google v srpnu oznámil, že na „certifikovaných“ zařízeních s Androidem omezí instalaci aplikací (včetně „sideloadingu“) tak, že bude vyžadovat, aby aplikace byly podepsány centrálně registrovanými vývojáři s ověřenou identitou. Iniciativa Keep Android Open se to snaží zvrátit. Podepsat lze otevřený dopis adresovaný Googlu nebo petici na Change.org.

    Ladislav Hagara | Komentářů: 0
    30.10. 15:22 | Nová verze

    Byla vydána nová verze 18 integrovaného vývojového prostředí (IDE) Qt Creator. S podporou Development Containers. Podrobný přehled novinek v changelogu.

    Ladislav Hagara | Komentářů: 2
    30.10. 12:55 | Nová verze

    Cursor (Wikipedie) od společnosti Anysphere byl vydán ve verzi 2.0. Jedná se o multiplatformní proprietární editor kódů s podporou AI (vibe coding).

    Ladislav Hagara | Komentářů: 1
    30.10. 02:55 | Nová verze

    Google Chrome 142 byl prohlášen za stabilní. Nejnovější stabilní verze 142.0.7444.59 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 20 bezpečnostních chyb. Za nejvážnější z nich bylo vyplaceno 50 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (35%)
     (48%)
     (19%)
     (18%)
     (23%)
     (16%)
     (21%)
     (16%)
     (17%)
    Celkem 292 hlasů
     Komentářů: 14, poslední 14.10. 09:04
    Rozcestník

    Dotaz: delete where id in (select)

    30.12.2010 23:14 depka | skóre: 20 | blog: eterity
    delete where id in (select)
    Přečteno: 764×
    proc v mysql nejde tento dotaz: http://pastebin.com/cq4781dR a jak ho pripadne prepsat aby neskonil chybovym hlasenim?

    Odpovědi

    30.12.2010 23:19 depka | skóre: 20 | blog: eterity
    Rozbalit Rozbalit vše Re: delete where id in (select)
    jeste prikladam chybou zpravu:
    #1093 - You can't specify target table 'wp_postmeta' for update in FROM clause
    a ucel dotazu: chci smazat duplicitni hodnoty ve sloupci meta_value, ktere se vyskytuji v jednom clanku(post_id)
    3.1.2011 12:35 FooBar
    Rozbalit Rozbalit vše Re: delete where id in (select)
    Tuhle hlasku dostanes proto, ze se snazis selectovat i mazat v te same tabulce. MySQL tohle nevydejcha.

    Pokud je to one-time event, rozdelil bych to na dva dotaz, jeden sezene ID, druhej je smaze. Nasledne bych na meta_value hodil unique constraint :)
    3.1.2011 19:44 jekub
    Rozbalit Rozbalit vše Re: delete where id in (select)
    delete from wp_postmeta where meta_id in
    (
    select max(meta_id) from 
    wp_postmeta 
    where meta_key in ('city','street','phones','faxs','url','mails','services','spec')
    group by post_id, meta_value having count(*) > 1
    )
    Mimochodem i kdyby ten dotaz na mysql fungoval, je spatne principialne. Pokud tam budou stejne hodnoty vice nez 2x... Spravne by tam melo byt not in.
    3.1.2011 20:09 depka | skóre: 20 | blog: eterity
    Rozbalit Rozbalit vše Re: delete where id in (select)
    ano, dokonce tam byly 3x, ale to vyresim ze ho spustim vicekrat
    3.1.2011 20:23 jekub
    Rozbalit Rozbalit vše Re: delete where id in (select)
    no tomu rikam reseni.
    3.1.2011 20:28 depka | skóre: 20 | blog: eterity
    Rozbalit Rozbalit vše Re: delete where id in (select)
    byla to jednorazova akce, resena o pulnoci...
    3.1.2011 11:54 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: delete where id in (select)
    DELETE FROM `wp_postmeta` WHERE `meta_id` IN
    (
      SELECT MAX(`meta_id`) AS `meta_id` FROM
        (SELECT `meta_id`, `meta_key`,`post_id`,`meta_value` FROM `wp_postmeta`) AS `t1`
          WHERE `t1`.`meta_key` IN ('city','street','phones','faxs','url','mails','services','spec')
            GROUP BY `post_id`, `meta_value` HAVING COUNT(*) > 1
    )
    
    Ten přidaný select může být i jako (SELECT * FROM `wp_postmeta`) AS `t1` a to `t1`.`meta_key` je tam jen na zdůraznění, stačí jen `meta_key`
    Takže stačí i:
    DELETE FROM `wp_postmeta` WHERE `meta_id` IN
    (
      SELECT max(`meta_id`) AS `meta_id` FROM
        (SELECT * FROM `wp_postmeta`) AS `t1`
          WHERE `meta_key` IN ('city','street','phones','faxs','url','mails','services','spec')
            GROUP BY `post_id`, `meta_value` HAVING COUNT(*) > 1
    )
    
    PS: Nároky na dotaz se asi zvyšují… :)
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    3.1.2011 19:36 depka | skóre: 20 | blog: eterity
    Rozbalit Rozbalit vše Re: delete where id in (select)
    takze reseni je jeste jednou vnorit do selectu, nechapu ale proc mysql vadi moje varianta, nejedna se prece o korelacni poddotaz
    3.1.2011 20:11 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: delete where id in (select)
    Odpovím Vám odkazem a jen dodám: „prostě je to tak“. :)
    Jen připomenu že ten „vnořený select“ je vlastně dočasně vytvořená tabulka všech záznamů, takže při roji řádků to bude náročné na zdroje.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Josef Kufner avatar 7.1.2011 02:34 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: delete where id in (select)
    Lze to udělat pomocí JOIN. Mysql nemá rádo subselecty z upravovaných tabulek, ale s joinama se vyrovná dobře.
    DELETE FROM ...
    JOIN ...
    WHERE ...
    V dokumentaci určitě pár příkladů najdeš.
    Hello world ! Segmentation fault (core dumped)

    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.