LINUXSOFT.cz Přeskoč levou lištu
Uživatel: Heslo:  
   CZUKPL

> MySQL (16) - Tipy a triky k manipulaci s daty

Něco o příkazu REPLACE. Také se dozvíte, jak lze jednoduše odstranit z tabulky duplicitní záznamy.

29.4.2005 15:00 | Petr Zajíc | Články autora | přečteno 49512×

Komerční sdělení: Pořádáme Kurzy MySQL

Již byla řeč o vkládání dat, o jejich aktualizaci i o jejich odstraňování. V souvislosti s tím si dovolím nabídnout několik tipů a triků, které se v této oblasti mohou hodit. Uvidíte, že MySQL může příjemně i nepříjemně překvapit.

Příkaz REPLACE

Příkaz REPLACE funguje podobně jako INSERT s tím, že za určitých okolností může některé řádky v tabulce přepsat. Přepsány budou záznamy, mající stejný primární klíč nebo jedinečný index. O indexech sice ještě v seriálu řeč nebyla, měli jsme však možnost zmínit se o primárních klíčích, a to v souvislosti s automaticky číslovanými řádky (ve skutečnosti to často je tak, že primární klíče tvoří právě automatická čísla řádků). Následuje příklad na REPLACE předpokládájící, že se rozhodneme vyměnit telefonní čísla v hypotetickém adresáři. Jako primární klíč poslouží e-mail uživatele:

create table replace_test (email varchar(50), jmeno varchar(50), telefon varchar(20), primary key (email));
insert into replace_test (email, jmeno) values('nekdo@nekde.cz', 'Někdo'),
('nekdojiny@nekdejinde.cz', 'Jára Cimrman');
replace into replace_test(email, jmeno) values('nekdo@nekde.cz', 'Úplně někdo jiný');

Pokud to zkusíte a prohlédnete si výsledky, zjistíte, že skutečně nebyl vložen třetí záznam, ale místo toho byl přepsán záznam druhý, protože souhlasil primární klíč - email. Upřímně řečeno, moc v lásce příkaz REPLACE nemám. A to ze tří důvodů:

  1. V praxi se mi ještě nepodařilo přijít na situaci, kdy by měl reálné využití. Mám na mysli převážně webové aplikace. Nevím, možná to souvisí s bodem č. 2 (Pokud však REPLACE používáte, šup s tím do diskuse pod článkem).
  2. Příkaz REPLACE je v SQL nestandardní. To znamená, že jej většina DBMS nemá a já si na něj nějak nemůžu zvyknout. Pochopitelně, že by podobná úloha šla řešit pomocí kombinace příkazu DELETE a INSERT.
  3. Nezapomeňte, že příkaz REPLACE maže celý řádek. V našem příkladu by to třeba znamenalo, že pokud bychom přepsali řádek s telefonem a nezadali nový telefon, ten původní tam v žádném případě NEZŮSTANE. Do nezadaných polí se totiž vloží výchozí hodnota (nebo hodnota NULL).

Příklad je zajímavý ještě něčím - všimněte si, že jako primární klíč jsme použili e-mail. Klíčem skutečně nemusí být jen číslo; měla by to však být informace, která se s dostatečnou zárukou nebude moci v tabulce opakovat. Například jméno to nesplňuje (že, Josefe Nováku?), e-mail, rodné číslo nebo číslo bankovního účtu však nejspíše ano.

Klauzule IGNORE

Bolení hlavy můžete mít z toho, když se vám povede během příkazu manipulujícího s daty způsobit v databázi chybu. Mějme například následujcí tabulku:

create table seznam (id int not null auto_increment, nazev varchar(50), primary key (id));

do níž vložíme naprosto nevinný řádek:

insert into seznam (nazev) values (2, 'druhý řádek');

Co se však stane, jestliže následně spustíme tento příkaz, který se pokusí vložit tři záznamy?

insert into seznam (id, nazev) values (1, 'první řádek'), (2, 'druhý řádek'), (3, 'třetí řádek');

Tento jeden příkaz by měl vložit tři položky, přičemž druhá z nich neprojde (obsahovala by duplicitu). Jak to dopadne? Nejspíš vás to překvapí, ale BUDE vložen první řádek - a následně příkaz skončí chybou. Dostáváme se do stavu, kdy část příkazu byla provedena, ale část ne. To je jedna z nejhorších věcí, které vás v databázovém světě mohou potkat. Jak z toho ven? Existují v zásadě dvě možnosti - buď všechny chyby ignorovat, nebo v případě jakékoli chyby VŮBEC NIC nevkládat. My se teď budeme zabývat tou první situací. V takovém případě stačí kouzelné rozšíření příkazu INSERT, a to o slovíčko IGNORE, takto:

insert ignore into seznam (id, nazev) values (1, 'první řádek'), (2, 'druhý řádek'), (3, 'třetí řádek');

To povede k tomu, že druhý záznam sice rovněž nebude vložen, ALE TEN TŘETÍ ANO. Neboli, všechny chyby budou tiše ignorovány a všechno, co půjde uložit se taky uloží.

Pozn.: Ten druhý způsob - nevkládat nic - popíšu zatím pouze náznakem. Něčeho takového lze v MySQL dosáhnout použitím transakcí a tabulek používajících transakce. Tam je totiž výchozí chován to, že chyba uprostřed příkazu zruší celý příkaz. A o tom ještě uslyšíme.

Kdy používat rozšíření IGNORE? Narozdíl od příkazu REPLACE mám několik tipů. Například v situaci, kdy chceme rychle něco někam vložit s tím, že to bude odkontrolováno později. Nebo mám pro vás speciální trik, kterým rychle odstraníte duplicitní řádky z tabulky.

Odstranění duplicit

To je poměrně častá úloha, kterou někteří programátoři řeší dost krkolomně. Přitom to lze provést i jednoduše. Mějme následující tabulku:

create table duplicity (soucastka varchar(50), poznamka varchar(50));
insert into duplicity (soucastka) values ('matička');
insert into duplicity (soucastka) values ('matička');
insert into duplicity (soucastka) values ('šroubeček');
insert into duplicity (soucastka) values ('šroubeček');
insert into duplicity (soucastka) values ('podložka');
insert into duplicity (soucastka) values ('podložka');
insert into duplicity (soucastka) values ('podložka');

a chtějme z ní odstranit duplicitní záznamy. Možná tomu nebudete věřit, ale s tím, co jsme se již v seriálu naučili to je hračka:

create table bezduplicit like duplicity;
alter table bezduplicit add primary key (soucastka);
insert ignore bezduplicit select * from duplicity;
drop table duplicity;
rename table bezduplicit to duplicity;

Co se vlastně stalo? Nejdřív jsme si vytvořili kopii naší původní tabulky. Pak jsme ji trochu předefinovali, a nakonec jsme se do ní pokusili vložit, co se dalo. Jelikož však nová tabulka nesmí obsahovat duplicitní údaje ve sloupci soucastka, povedlo se vždy jen takové vložení, které se ještě neopakovalo. Ale, příkaz neskončí na první chybě, naopak pokračuje. Tento způsob vyčištění zdvojených (ztrojených ...) záznamů je jeden z nejrychlejších. Příliš jej nespomaluje ani počet duplicitních záznamů, ani  to, kolikrát se jednotlivé hodnoty opakují. Výhodou je rovněž to, že z prvních vyhovoujících záznamů by byly vloženy i údaje z dalších sloupců (jako je naše poznámka). Čistě pro pořádek jsem ještě původní tabulku odstranil a tu novou přejmenoval.

V dalším díle seriálu se začneme zabývat poměrně rozsáhlou látkou - a tou bude vybírání záznamů pomocí příkazu SELECT.

Verze pro tisk

pridej.cz

 

DISKUZE

PRIMARY KEY 29.4.2005 23:27 Josef Panak
Primární klíč 1.5.2005 20:35 Petr Zajíc
ještě k odstranění duplicit 5.5.2005 07:03 pogik
L Re: ještě k odstranění duplicit 7.5.2005 17:37 Petr Zajíc
  L Re: ještě k odstranění duplicit 11.5.2005 08:04 MaReK Olšavský
INSERT a DELETE 1.6.2006 09:31 Aleš Dostál




Příspívat do diskuze mohou pouze registrovaní uživatelé.
> Vyhledávání software
> Vyhledávání článků

15.4.2017 15:20 /František Kučera

Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě IoT a radiokomunikace? Přijď na sraz spolku OpenAlt, který se bude konat ve středu 19. dubna od 18:30 v Šenkovně (Sokolská 60, Praha 2).


Přidat komentář

5.3.2017 19:12 /Redakce Linuxsoft.cz
PR: 23. března proběhne v Praze konferenci na téma Cloud computing v praxi. Hlavními tématy jsou: Nejžhavější trendy v oblasti cloudu a cloudových řešení, Moderní cloudové služby, Infrastruktura současných cloudů, Efektivní využití cloudu, Nástrahy cloudových řešení a jak se jim vyhnout.
Přidat komentář

27.2.2017 22:12 /František Kučera
Pozvánka na 137. sraz OpenAlt – Praha: Tentokrát jsme si pro vás připravili neobvyklou akci. Ve středu 1.3. v 17:30 nás přivítá sdružení CZ.NIC ve svých prostorách v Milešovské ulici číslo 5 na Praze 3, kde si pro nás připravili krátkou prezentaci jejich činnosti. Následně navštívíme jejich datacentrum pod Žižkovskou věží. Provedou nás prostory, které jsou běžnému smrtelníkovi nedostupné!
Po ukončení prohlídky se všchni odebereme do hostince U vodoucha, Jagelonská 21, Praha 3 pochutnat si na některém z vybraných piv či dát si něco na zub. Rezervaci máme od 19:30, heslo je OpenAlt.
Ale pozor! Do prostor datového centra máme omezený přístup, dostane se tam pouze 10 lidí! Takže kdo přijde dříve, ten má přednost, a občanky s sebou! Kdo nebude chtít na prohlídku datového centra, může se pomalu přesunout do hostince U vodoucha a u nepřeberné nabídky piv počkat na ostatní.
Přidat komentář

18.1.2017 0:49 /František Kučera
Členové a příznivci spolku OpenAlt se pravidelně schází v Praze a Brně. Fotky z pražských srazů za uplynulý rok si můžete prohlédnout na stránkách spolku. Příští sraz se koná už 19. ledna – tentokrát je tématem ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. Také budete mít příležitost si prohlédnout pražský hackerspace Brmlab.
Přidat komentář

8.1.2017 17:51 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Přijď na sraz spolku OpenAlt, který se bude konat ve čtvrtek 19. ledna od 18:30 v pražském hackerspacu Brmlab. Tentokrát je tématem srazu ergonomie ovládání počítače – tzn. klávesnice, myši a další zařízení. K vidění bude mechanická klávesnice dasKeyboard, trackball Logitech nebo grafický tablet (a velký touchpad) Wacom. Přineste i vy ukázat svoje zajímavé klávesnice a další HW. V 18:20 je sraz před budovou, v 18:30 jdeme společně dovnitř, je tedy dobré přijít včas. Podle zájmu se později přesuneme do nějaké restaurace v okolí.
Přidat komentář

1.12.2016 22:13 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Přijď na sraz spolku OpenAlt, který se bude konat ve čtvrtek 8. prosince od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Sraz bude tentokrát tématický. Bude retro! K vidění budou přístroje jako Psion 5mx nebo Palm Z22. Ze svobodného hardwaru pak Openmoko nebo čtečka WikiReader. Přijďte se i vy pochlubit svými legendami, nebo alespoň na pivo. Moderní hardware má vstup samozřejmě také povolen.
Komentářů: 1

4.9.2016 20:13 /Pavel `Goldenfish' Kysilka
PR: Dne 22.9.2016 proběhne v Praze konference Cloud computing v praxi. Tématy bude např. nejnovější trendy v oblasti cloudu a cloudových řešení, provozování ERP v cloudu, o hostování různých typů softwaru, ale třeba i o zálohování dat nabízeném podnikům formou služby.
Přidat komentář

1.9.2016 11:27 /Honza Javorek
Česká konference o Pythonu, PyCon CZ, stále hledá přednášející skrz dobrovolné přihlášky. Máte-li zajímavé téma, neváhejte a zkuste jej přihlásit, uzávěrka je již 12. září. Konference letos přijímá i přednášky v češtině a nabízí pomoc s přípravou začínajícím speakerům. Řečníci mají navíc vstup zadarmo! Více na webu.
Přidat komentář

   Více ...   Přidat zprávičku

> Poslední diskuze

17.4.2017 19:15 / Jakub shoop
chyba

7.4.2017 15:43 / Som
foreign car repair

31.3.2017 18:33 / David Ostrovsky
Dotazník na obeznámenost s hummusem.

24.3.2017 11:54 / Hui
country cottages

16.3.2017 16:33 / BezvaDesign.cz
Re: Hledám grafika do teamu

Více ...

ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2017) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze