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 16:00 | Nová verze

Byl vydán Mozilla Firefox 51.0. Z novinek lze upozornit například na upozorňování na přihlašování přes nešifrované spojení (HTTP), podporu pro přehrávání bezeztrátového formátu FLAC nebo podporu WebGL 2. Podrobné informace v poznámkách k vydání a na stránce věnované vývojářům. Řešeny jsou také bezpečnostní chyby.

Ladislav Hagara | Komentářů: 0
včera 17:25 | IT novinky

Do prodeje (Farnell) se dostal jednodeskový počítač Tinker Board (unboxing). Jedná se o konkurenci Raspberry Pi 3 od společnosti Asus. Porovnání (jpg) těchto počítačů například na CNXSoft. Cena Tinker Boardu je 55 £.

Ladislav Hagara | Komentářů: 13
včera 14:44 | Zajímavý projekt

Byla zveřejněna pravidla hackerské soutěže Pwn2Own 2017, jež proběhne od 15. do 17. března v rámci bezpečnostní konference CanSecWes ve Vancouveru. Soutěžit se bude o více než milion dolarů v pěti kategoriích. Letos se bude útočit i na Ubuntu. Jedná se již o 10. ročník této soutěže.

Ladislav Hagara | Komentářů: 2
včera 13:33 | Nová verze

Po sedmi měsících vývoje od vydání verze 5.7 byla vydána verze 5.8 (YouTube) toolkitu Qt. Z novinek lze zmínit například Qt Lite pro vestavěná zařízení. Nově jsou plně podporovány moduly Qt Wayland Compositor (YouTube) a Qt SCXML (YouTube). Současně byla vydána verze 4.2.1 integrovaného vývojového prostředí (IDE) Qt Creator.

Ladislav Hagara | Komentářů: 1
včera 11:52 | Pozvánky

Lednový Prague Containers Meetup se koná ve čtvrtek 26. ledna 2017 od 18:00 v Apiary, Pernerova 49, Praha 8. Přijďte se podívat na přednášky o Enterprise Kubernetes a Jenkins as a code.

little-drunk-jesus | Komentářů: 0
včera 11:40 | Pozvánky

Program letošního ročníku konference Prague PostgreSQL Developer Days, která se koná již 15. a 16. února 2017 na ČVUT FIT, Thákurova 9, Praha 6, byl dnes zveřejněn. Najdete ho na stránkách konference včetně anotací přednášek a školení. Registrace na konferenci bude otevřena zítra (24. ledna) v brzkých odpoledních hodinách.

TomasVondra | Komentářů: 0
22.1. 02:20 | Zajímavý článek

David Revoy, autor open source webového komiksu Pepper&Carrot nebo portrétu GNU/Linuxu, upozorňuje na svém blogu, že nový Inkscape 0.92 rozbíjí dokumenty vytvořené v předchozích verzích Inkscape. Problém by měl být vyřešen v Inkscape 0.92.2 [reddit].

Ladislav Hagara | Komentářů: 0
22.1. 02:02 | Komunita

Øyvind Kolås, hlavní vývojář grafických knihoven GEGL a babl, které využívá grafický program GIMP, žádá o podporu na Patreonu. Díky ní bude moci pracovat na vývoji na plný úvazek. Milník 1000 $, který by stačil na holé přežití, se již téměř podařilo vybrat, dalším cílem je dosažení 2500 $, které mu umožní běžně fungovat ve společnosti.

xkomczax | Komentářů: 12
21.1. 23:54 | Pozvánky

DevConf.cz 2017, již devátý ročník jedné z největších akcí zaměřených na Linux a open source ve střední Evropě, proběhne od pátku 27. ledna do neděle 29. ledna v prostorách Fakulty informačních technologií Vysokého učení technického v Brně. Na programu je celá řada zajímavých přednášek a workshopů. Letos je povinná registrace.

Ladislav Hagara | Komentářů: 0
21.1. 22:11 | Nová verze

Byla vydána verze 1.0.0 emulátoru terminálu Terminology postaveného nad EFL (Enlightenment Foundation Libraries). Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (12%)
 (2%)
 (72%)
 (3%)
 (11%)
Celkem 393 hlasů
 Komentářů: 37, poslední dnes 12:21
Rozcestník
Reklama

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: 706×
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: 66
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.