abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 04:55 | Nová verze

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

    Ladislav Hagara | Komentářů: 0
    dnes 04:22 | Nová verze

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

    Ladislav Hagara | Komentářů: 4
    včera 15:55 | Nová verze

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | IT novinky

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

    Ladislav Hagara | Komentářů: 0
    včera 04:44 | Nová verze

    Po roce vývoje od vydání verze 1.24.0 byla vydána nová stabilní verze 1.26.0 webového serveru a reverzní proxy nginx (Wikipedie). Nová verze přináší řadu novinek. Podrobný přehled v souboru CHANGES-1.26.

    Ladislav Hagara | Komentářů: 0
    včera 04:33 | Nová verze

    Byla vydána nová verze 6.2 živé linuxové distribuce Tails (The Amnesic Incognito Live System), jež klade důraz na ochranu soukromí uživatelů a anonymitu. Přehled změn v příslušném seznamu. Tor Browser byl povýšen na verzi 13.0.14.

    Ladislav Hagara | Komentářů: 0
    včera 04:22 | Nová verze

    Byla vydána nová verze 30.0.0 frameworku pro vývoj multiplatformních desktopových aplikací pomocí JavaScriptu, HTML a CSS Electron (Wikipedie, GitHub). Chromium bylo aktualizováno na verzi 124.0.6367.49, V8 na verzi 12.4 a Node.js na verzi 20.11.1. Electron byl původně vyvíjen pro editor Atom pod názvem Atom Shell. Dnes je na Electronu postavena celá řada dalších aplikací.

    Ladislav Hagara | Komentářů: 2
    včera 04:11 | Nová verze

    Byla vydána nová verze 9.0.0 otevřeného emulátoru procesorů a virtualizačního nástroje QEMU (Wikipedie). Přispělo 220 vývojářů. Provedeno bylo více než 2 700 commitů. Přehled úprav a nových vlastností v seznamu změn.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (9%)
     (2%)
     (17%)
    Celkem 731 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    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: 735×
    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.