Smazání duplicitních záznamů – MySQL – Fórum – Programujte.com
 x   TIP: Přetáhni ikonu na hlavní panel pro připnutí webu

Smazání duplicitních záznamů – MySQL – Fórum – Programujte.comSmazání duplicitních záznamů – MySQL – Fórum – Programujte.com

 

survik1
~ Moderátor
0
Posthunter
24. 4. 2009   #1
-
0
-

Zdravím. Při vývoji jednoho projektu jsem se dopustil řady chyb v kódu, vohužel nejkrytičtější je právě v DB (kde se těžko opravuje). Bohužel se mi podařilo nahárt mnoho duplicictních hodnot. Potřeboval bych, aby se smazali všechny duplicitní hodnoty s vyšším ID, jak originál (originál má nižší ID, v případě existence duplikátu mají duplikáty ID zpravidla o jedno až n vyšší). Existuje pro to příkaz? Nebo si to musím sám sestavit přes PHP? Děkuji.

Nahlásit jako SPAM
IP: 89.102.156.–
Život je jen hra, která se nedá vyhrát.
bukaj_0010
Věrný člen
25. 4. 2009   #2
-
0
-

survik1
Existuje pro to příkaz? Nebo si to musím sám sestavit přes PHP?

-- uděláme si kopii

CREATE TABLE tabulka_kopie LIKE tabulka;

-- přidáme unique index, aby se vyfiltrovala duplikátní data
ALTER TABLE tabulka_kopie ADD UNIQUE muj_unique_index (moje, unikatni, sloupce);

-- přelijeme data do nově vytvořené tabulky
INSERT IGNORE INTO tabulka_kopie SELECT * FROM tabulka;

-- volitelně: odstraníme unique index
ALTER TABLE tabulka_kopie DROP INDEX muj_unique_index;

-- „přelijeme“ data zpátky
DROP TABLE tabulka;
ALTER TABLE tabulka_kopie RENAME TO tabulka;

Nahlásit jako SPAM
IP: 88.101.128.–
Jak se správně ptát? -> http://www.hash.cz/inferno/otazky.html[br][br] Po programování je člověk hladovej.
pawlik0
Grafoman
25. 4. 2009   #3
-
0
-

Ještě bych to možná dal do transakce, protože pak to někde uvízne a tabulka zůstane.
A jinak mě ještě napadlo, nedalo by se to řešit přes VIEWs?

Nahlásit jako SPAM
IP: 84.42.151.–
Sa Nata A Na. Howgh
Zjistit počet nových příspěvků

Přidej příspěvek

Toto téma je starší jak čtvrt roku – přidej svůj příspěvek jen tehdy, máš-li k tématu opravdu co říct!

Ano, opravdu chci reagovat → zobrazí formulář pro přidání příspěvku

×Vložení zdrojáku

×Vložení obrázku

Vložit URL obrázku Vybrat obrázek na disku
Vlož URL adresu obrázku:
Klikni a vyber obrázek z počítače:

×Vložení videa

Aktuálně jsou podporována videa ze serverů YouTube, Vimeo a Dailymotion.
×
 
Podporujeme Gravatara.
Zadej URL adresu Avatara (40 x 40 px) nebo emailovou adresu pro použití Gravatara.
Email nikam neukládáme, po získání Gravatara je zahozen.
-
Pravidla pro psaní příspěvků, používej diakritiku. ENTER pro nový odstavec, SHIFT + ENTER pro nový řádek.
Sledovat nové příspěvky (pouze pro přihlášené)
Sleduj vlákno a v případě přidání nového příspěvku o tom budeš vědět mezi prvními.
Reaguješ na příspěvek:

Uživatelé prohlížející si toto vlákno

Uživatelé on-line: 0 registrovaných, 18 hostů

 

Hostujeme u Českého hostingu       ISSN 1801-1586       ⇡ Nahoru Webtea.cz logo © 20032024 Programujte.com
Zasadilo a pěstuje Webtea.cz, šéfredaktor Lukáš Churý