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

> MySQL (42) - ještě k transakcím

Dnes si ukážeme nějaké praktické příklady transakcí.

14.10.2005 06:00 | Petr Zajíc | Články autora | přečteno 23327×

Dnes se budu snažit o přiblížení toho, jak by měly transakce fungovat v praxi. Takže se můžete těšit na nějaký ten příklad.

Příklady na transakce

Každý se snaží při uvádění příkladů na transakce použít převod peněz z účtu na účet. Je to tak otřepané, že to snad ani víc otřepat nejde; takže se vydáme trochu jinou cestou - a budeme přitom postupovat od jednoduchých příkladů ke složitějším. Jak jsme již uvedli v některém z minulých dílů, v MySQL jsou tabulky podporovány pouze pro některé typy tabulek - konkrétně pro InnoDB a BDB. Častější je použití InnoDB, takže budeme v příkladech používat tabulky tohoto typu. V souvislosti s transakcemi si pravděpodobně budete chtít zapamatovat příkazy, které je řídí:

Příkaz
Význam
START TRANSACTION
Zahájí neboli odstartuje transakci. Veškeré příkazy zadané později jsou součástí transakce a navenek se tedy budou jevit jako jediný příkaz.
COMMIT
Aktuální transakce je potvrzena. Změny jsou zapsány do databáze a jsou uvolněny systémové prostředky, které si transakce vyžádala.
ROLLBACK
Aktuální transakce je zamítnuta. Všechny provedené změny jsou zrušeny a databáze se vrátí do stavu, v němž byla před zahájením transakce.

Pojďme si to celé ukázat na příkladu. Dejme tomu, že pracujete ve firmě, kde se rozhodnout rapidně zvýšit platy. Půjde se na to tak, že lidem, kteří měli méně než 15000,-Kč bude přidáno 2000,- Kč a následně bude všem zvýšen plat o 10% (hezká představa, že?). Pochopitelně, že to celé zrealizujeme pomocí transakce. Proč? Taková transakce nám zajistí, že:

  1. Během celé operace nebude s platy moci hýbat nikdo jiný. Uvědomte si, že ve víceuživatelských systémech by se to klidně mohlo stát.
  2. Celá operace se provede (nebo se celá neprovede). Asi byste zrovna nechtěli být na řadě, když by chudáku serveru někdo vypnul proud právě ve chvíli, kdy se chystá aktualizovat váš plat.
  3. Navíc, představte si, že byste byli na místě člověka, který to má dát do pořádku poté, co se polovina záznamů zaktualizovala a druhá polovina nikoli.

Vytvořme tedy nějakou tabulku:

create table platy (zamestnanec varchar(50), plat int) type=innodb;

naplňme ji daty:

insert into platy values ('Jarda',12000);
insert into platy values ('Pepa',15000);
insert into platy values ('Petr',14000);
insert into platy values ('Pavel',10000);
insert into platy values ('Šárka',16000);
insert into platy values ('Monika',13000);

a zkusme to celé provést. Půjdeme na to takto:

start transaction;
update platy set plat=plat+2000 where plat < 15000;
update platy set plat=plat*1.1;
commit;

Za zmínku stojí, že kdyby se pokusil během naší transakce o úpravu dat někdo jiný, byl by odmítnut. To lze lehce ověřit, pokud si zkusíte dva paralelně běžící klienty (nejlépe asi v konzoli):

klient 1
klient 2
Popis
start transaction

Spustí transakci
update platy set plat=plat+2000 where plat < 15000;

Transakce změnila tabulku, ale ještě nevíme, zda se to potvrdí nebo odvolá

update platy set plat=plat
Tento příkaz nemůže být ihned proveden, protože data jsou blokována předchozí transakcí. Na vykonání nějakou dobu čeká a pokud je tato doba vyčerpána, skončí chybou "lock wait timeout exceeded"
update platy set plat=plat*1.1; (čeká)
Transakce opět změnila tabulku; stále nevíme, zda se to potvrdí či nikoli
commit;
(čeká)
Transakce je dokončena, změny jsou zapsány a tabulka je volná.

proveden!
Pokud transakce byla dokončena dostatečně včas, přichází na řadu příkaz z klienta č. 2 (pokud ne, je zahozen)

Automatické transakce

Je třeba si uvědomit, že při zadávání příkazů do tabulek InnoDB nebo BDB je vždy spuštěna transakce. Možná se vám to nezdá, ale při zadání příkazu:

select * from cosi;

Provede databáze ve skutečnosti toto:

start transaction;
select * from cosi;
commit;

To proto, že transakce bez zadaného příkazu start transaction jsou automaticky dokončovány. Někdy by Vám ale mohlo vyhovovat spíše to, že zadáte sadu příkazu a sami je potvrdíte pomocí COMMIT. Něco takového se dá nastavit pomocí konfigurační volby autocommit:

SET AUTOCOMMIT=0;

Pozor ale, není to volba databáze, nybrž jednotlivého spojení. Pokud bude spojení ukončeno, přejde databáze zpět do režimu automaticky dokončovaných transakcí. V této souvislosti je rovněž dobré si uvědomit, že existují příkazy, které vždy dokončují transakci (bez ohledu na to, zda jsou úspěšné či nikoli). Jinými slovy, na těchto příkazech nelze vykonat ROLLBACK. Patří mezi ně převážně příkazy pro definici struktur, jako jsou:

  • CREATE DATABASE
  • CREATE TABLE
  • CREATE INDEX
  • ALTER ...
  • DROP ...
  • TRUNCATE

Proto byste se použití těchto příkazů v transakcích měli spíše vyhýbat.

Verze pro tisk

pridej.cz

 

DISKUZE

Oprava 16.10.2005 23:32 Jan Baroš
  L Re: Oprava 24.10.2005 10:27 František Hallo




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

16.7.2018 1:05 /František Kučera

Červencový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 7. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát bude přednáška na téma: automatizační nástroj Ansible, kterou si připravil Martin Vicián.


Přidat komentář

18.6.2018 0:43 /František Kučera
Červnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 21. 6. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: F-Droid, aneb svobodný software do vašeho mobilu. Kromě toho budou k vidění i vývojové desky HiFive1 se svobodným/otevřeným čipem RISC-V.
Přidat komentář

23.5.2018 20:55 /Ondřej Čečák
Od pátku 25.5. proběhne na Fakultě informačních technologií ČVUT v Praze openSUSE Conference. Můžete se těšit na spostu zajímavých přednášek, workshopů a také na Release Party nového openSUSE leap 15.0. V na stejném místě proběhne v sobotu 26.5. i seminář o bezpečnosti CryptoFest.
Přidat komentář

20.5.2018 17:45 /Redakce Linuxsoft.cz
Ve čtvrtek 31. května 2018 připravuje webový magazín BusinessIT ve spolupráci s Best Online Média s.r.o. pátý ročník odborné konference Firemní informační systémy 2018. Akce proběhne v kongresovém centru Vavruška (palác Charitas), Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00 hod. dopoledne do cca 15 hod. odpoledne. Konference je zaměřena na efektivní využití firemních informačních systémů a na to, jak plně využít jejich potenciál. Podrobnější informace na webových stránkách konfrence.
Přidat komentář

14.5.2018 7:28 /František Kučera
Květnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 17. 5. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát na téma: Audio – zvuk v GNU/Linuxu.
Přidat komentář

7.5.2018 16:20 /František Kučera
Na stránkách spolku OpenAlt vyšla fotoreportáž Pražské srazy 2017 dokumentující srazy za uplynulý rok. Květnový pražský sraz na téma audio se bude konat 17. 5. 2018 (místo a čas ještě upřesníme).
Přidat komentář

17.4.2018 0:46 /František Kučera
Dubnový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 19. 4. 2018 od 18:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tématem tohoto srazu bude OpenStreetMap (OSM) aneb svobodné mapy.
Přidat komentář

16.3.2018 22:01 /František Kučera
Kulatý OpenAlt sraz v Praze oslavíme klasicky: u limonády a piva! Přijďte si posedět, dát si dobré jídlo a vybrat z mnoha piv do restaurace Kulový blesk, který najdete v centru Prahy nedaleko metra I. P. Pavlova na adrese Sokolská 13, Praha 2. Sraz se koná ve čtvrtek 22. března a začínáme v 18:00. Heslo: OpenAlt. Vezměte s sebou svoje hračky! Uvítáme, když si s sebou na sraz vezmete svoje oblíbené hračky. Jestli máte nějaký drobný projekt postavený na Arduinu, nějakou zajímavou elektronickou součástku, či třeba i pěkný úlovek z crowdfundingové akce, neváhejte. Oslníte ostatní a o zábavu bude postaráno.
Přidat komentář

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

> Poslední diskuze

20.2.2018 18:48 / Ivan Majer
portal

20.2.2018 15:57 / Jan Havel
Jak využíváte služby cloudu v podnikání?

16.1.2018 1:08 / Ivan Pittner
verejna ip od o2 ubuntu

15.1.2018 17:26 / Mira Harvalik
Re: Jak udělat HTML/Javascript swiping gallery do mobilu?

30.12.2017 20:16 / Michal Knoll
odmocnina

Více ...

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