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

    VirtualBox, tj. multiplatformní virtualizační software, byl vydán v nové verzi 7.2. Přehled novinek v Changelogu. Vypíchnou lze vylepšené GUI.

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

    Eric Migicovsky, zakladatel společnosti Pebble, v lednu oznámil, že má v plánu spustit výrobu nových hodinek Pebble s již open source PebbleOS. V březnu spustil předprodej hodinek Pebble Time 2 (tenkrát ještě pod názvem Core Time 2) za 225 dolarů s dodáním v prosinci. Včera představil jejich konečný vzhled (YouTube).

    Ladislav Hagara | Komentářů: 2
    včera 12:44 | Zajímavý software

    Byla oznámena nativní podpora protokolu ACME (Automated Certificate Management Environment) ve webovém serveru a reverzní proxy NGINX. Modul nginx-acme je zatím v preview verzi.

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

    Vývojáři KDE oznámili vydání balíku aplikací KDE Gear 25.08. Přehled novinek i s náhledy a videi v oficiálním oznámení.

    Ladislav Hagara | Komentářů: 0
    13.8. 11:55 | IT novinky

    Společnost Perplexity AI působící v oblasti umělé inteligence (AI) podala nevyžádanou nabídku na převzetí webového prohlížeče Chrome internetové firmy Google za 34,5 miliardy dolarů (zhruba 723 miliard Kč). Informovala o tom včera agentura Reuters. Upozornila, že výše nabídky výrazně převyšuje hodnotu firmy Perplexity. Společnost Google se podle ní k nabídce zatím nevyjádřila.

    Ladislav Hagara | Komentářů: 5
    13.8. 04:33 | Bezpečnostní upozornění

    Intel vydal 34 upozornění na bezpečnostní chyby ve svých produktech. Současně vydal verzi 20250812 mikrokódů pro své procesory řešící 6 bezpečnostních chyb.

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

    Byla vydána nová verze 1.25 programovacího jazyka Go (Wikipedie). Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 1
    12.8. 13:44 | Nová verze

    Byla vydána beta verze Linux Mintu 22.2 s kódovým jménem Zara. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze novou XApp aplikaci Fingwit pro autentizaci pomocí otisků prstů nebo vlastní fork knihovny libAdwaita s názvem libAdapta podporující grafická témata. Linux Mint 22.2 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 0
    12.8. 13:00 | IT novinky

    Provozovatel internetové encyklopedie Wikipedie prohrál v Británii soudní spor týkající se některých částí nového zákona o on-line bezpečnosti. Soud ale varoval britského regulátora Ofcom i odpovědné ministerstvo před zaváděním přílišných omezení. Legislativa zpřísňuje požadavky na on-line platformy, ale zároveň čelí kritice za možné omezování svobody slova. Společnost Wikimedia Foundation, která je zodpovědná za fungování

    … více »
    Ladislav Hagara | Komentářů: 2
    12.8. 12:55 | Nová verze

    Byla vydána verze 2.0.0 nástroje pro synchronizaci dat mezi vícero počítači bez centrálního serveru Syncthing (Wikipedie). Přehled novinek na GitHubu.

    Ladislav Hagara | Komentářů: 3
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (52%)
     (19%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (17%)
    Celkem 393 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: MYSQL zmazanie duplicít

    14.2.2012 10:35 adrinko | skóre: 22
    MYSQL zmazanie duplicít
    Přečteno: 842×
    zdravím vospolok, prosím Vás, mám v db tabuľku s id_dres a id_hrac. Z času na čas potrebujem skontrolovať, či sa jeden a ten istý hráč, t.j. s rovnakým id_hrac nenachádza v tabuľke viackrát, teda že by mal rovnaké aj id_dres. ako najrýchlejšie by sa dali vypísať len ten/tí hráč/hráči, ktorí sú s rovnakým id_dres viackrát v tabuľke? následne by som ich potom chcel premazať tak, aby sa tam vyskytoval každý hráč len raz. (prosím, preskočme myšlienky ošetrovania vkladania duplicít)

    id_hrac id_dres

    1 34

    2 120

    1 34

    malo by mi teda vypísať, že hráč č.1 je viackrát v db a následne by som ich chcel po potvrdení užívateľom premazať tak, aby sa tam nevyskytovali viackrát. vďaka

    Řešení dotazu:


    Odpovědi

    14.2.2012 11:45 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: MYSQL zmazanie duplicít
    Nevím, proč neudělat unique index nad oběmi sloupci a neřešit to, ale vybrat duplicitní položky lze takto:
    SELECT
      id_hrac
     ,id_dres
     ,count(id_hrac) as count 
    FROM
      table 
    GROUP BY 
      1,2 
    HAVING
      count > 1
    
    A nebo tym vytvořit index a místo INSERT používat REPLACE, podle mě není v pořásku, že tam ty duplicity vůbec vznikají.
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    14.2.2012 13:28 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: MYSQL zmazanie duplicít
    A co se týká odstranění duplict, mělo by fungovat zhruba toto
    ALTER IGNORE TABLE `table` ADD UNIQUE INDEX dupidx (id_hrac, id_dres);
    ALTER TABLE `table` DROP INDEX dupidx;
    
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    14.2.2012 23:54 adrinko | skóre: 22
    Rozbalit Rozbalit vše Re: MYSQL zmazanie duplicít
    vďaka za poradenie. ešte podotázka k alter ignore. V tabuľke by som chcel odstrániť len tie duplikáty, ktoré sú ešte platné pre id_skupiny = 22. T.j. aby ti zhodnotilo len záznamy so stĺpcom id_skupiny = 22, a ostatné nechalo na pokoji. Ako by sa to dalo upraviť s touto podmienkou, aby sa to týkalo len tej určitej skupiny?

    P.S. ten alter ignore sa mi nepodarilo úspešne rozchodiť, zatiaľ to končí chybou 'Duplicate entry '2-2' for key 'dupidx''
    15.2.2012 09:13 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: MYSQL zmazanie duplicít
    A jaká je to verze mysql, protože jsem koukal do manuálu a mělo by to duplicity odstranit viz ALTER TABLE Syntax.
    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    rADOn avatar 15.2.2012 14:20 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: MYSQL zmazanie duplicít
    Ten alter zadne existujici duplikaty neodstrani, to musis udelat rucne. Ale az to udelas unikatni index zabrani dalsimu vlozeni duplikatu, cili uz se od te chvile budes moci spolehnout ze uz zadne duplikaty nebudou. Aplikace ktera to tam ty zaznamy vklada ale musi byt pripravena na to, ze ji najednou zacnou pri pokusu o vlozeni duplicity vystrelovat chyby. Krome toho klic zabere nejake misto, ale pokud nejsou ty tabulky vyslovene giganticke neni to problem.

    Aplikovat klic pouze na urcite hodnoty MySQL afaik neumi. Pokud je to dulezite, muzes to obejit tak, ze pridas do klice synteticky sloupec ktery bude obsahovat unikatni hodnotu (mel by fungovat auto_increment) pro ty radky ktere smeji byt duplicitni (tim padem cely klic bude unikatni) a pro ostatni v nem bude nejaka konstanta.

    Nebo by to slo vyresit triggerem ktery to zkontroluje pri pridavani radku, to by bylo kapku slozitejsi (a imo ne tak robustni) ale bez zmen ve schematu.

    "2^24 comments ought to be enough for anyone" -- CmdrTaco
    15.2.2012 15:19 blondak | skóre: 36 | blog: Blondak | Čáslav
    Rozbalit Rozbalit vše Re: MYSQL zmazanie duplicít
    z dokumentace:

    IGNORE is a MySQL extension to standard SQL. It controls how ALTER TABLE works if there are duplicates on unique keys in the new table or if warnings occur when strict mode is enabled. If IGNORE is not specified, the copy is aborted and rolled back if duplicate-key errors occur. If IGNORE is specified, only the first row is used of rows with duplicates on a unique key. The other conflicting rows are deleted. Incorrect values are truncated to the closest matching acceptable value.

    Každý problém ma své logické, snadno pochopitelné nesprávné řešení.
    rADOn avatar 16.2.2012 18:14 rADOn | skóre: 44 | blog: bloK | Praha
    Rozbalit Rozbalit vše Re: MYSQL zmazanie duplicít
    To jsem nevěděl. Jdu se stydět do kouta…
    "2^24 comments ought to be enough for anyone" -- CmdrTaco

    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.