![]() ![]() |
ARCHIV |
|||||||||||||||||||||||||||||||||
![]() ![]() ![]() ![]() ![]() ![]() |
|
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:
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) |
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:
Proto byste se použití těchto příkazů v transakcích měli spíše vyhýbat.
Příspívat do diskuze mohou pouze registrovaní uživatelé. |
28.11.2018 23:56 /František Kučera
Prosincový sraz spolku OpenAlt se koná ve středu 5.12.2018 od 16:00 na adrese Zikova 1903/4, Praha 6. Tentokrát navštívíme organizaci CESNET. Na programu jsou dvě přednášky: Distribuované úložiště Ceph (Michal Strnad) a Plně šifrovaný disk na moderním systému (Ondřej Caletka). Následně se přesuneme do některé z nedalekých restaurací, kde budeme pokračovat v diskusi.
Komentářů: 1
12.11.2018 21:28 /Redakce Linuxsoft.cz
22. listopadu 2018 se koná v Praze na Karlově náměstí již pátý ročník konference s tématem Datová centra pro business, která nabídne odpovědi na aktuální a často řešené otázky: Jaké jsou aktuální trendy v oblasti datových center a jak je optimálně využít pro vlastní prospěch? Jak si zajistit odpovídající služby datových center? Podle jakých kritérií vybírat dodavatele služeb? Jak volit vhodné součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně datové centrum spravovat? Jak co nejlépe eliminovat možná rizika? apod. Příznivci LinuxSoftu mohou při registraci uplatnit kód LIN350, který jim přinese zvýhodněné vstupné s 50% slevou.
Přidat komentář
6.11.2018 2:04 /František Kučera
Říjnový pražský sraz spolku OpenAlt se koná v listopadu – již tento čtvrtek – 8. 11. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma umění a technologie, IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
4.10.2018 21:30 /Ondřej Čečák
LinuxDays 2018 již tento víkend, registrace je otevřená.
Přidat komentář
18.9.2018 23:30 /František Kučera
Zářijový pražský sraz spolku OpenAlt se koná již tento čtvrtek – 20. 9. 2018 od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Tentokrát bez oficiální přednášky, ale zato s dobrým jídlem a pivem – volná diskuse na téma IoT, CNC, svobodný software, hardware a další hračky.
Přidat komentář
9.9.2018 14:15 /Redakce Linuxsoft.cz
20.9.2018 proběhne v pražském Kongresovém centru Vavruška konference Mobilní řešení pro business.
Návštěvníci si vyslechnou mimo jiné přednášky na témata: Nejdůležitější aktuální trendy v oblasti mobilních technologií, správa a zabezpečení mobilních zařízení ve firmách, jak mobilně přistupovat k informačnímu systému firmy, kdy se vyplatí používat odolná mobilní zařízení nebo jak zabezpečit mobilní komunikaci.
Přidat komentář
12.8.2018 16:58 /František Kučera
Srpnový pražský sraz spolku OpenAlt se koná ve čtvrtek – 16. 8. 2018 od 19:00 v Kavárně Ideál (Sázavská 30, Praha), kde máme rezervovaný salonek. Tentokrát jsou tématem srazu databáze prezentaci svého projektu si pro nás připravil Standa Dzik. Dále bude prostor, abychom probrali nápady na využití IoT a sítě The Things Network, případně další témata.
Přidat komentář
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ář
31.7.2023 14:13 /
Linda Graham
iPhone Services
30.11.2022 9:32 /
Kyle McDermott
Hosting download unavailable
13.12.2018 10:57 /
Jan Mareš
Re: zavináč
2.12.2018 23:56 /
František Kučera
Sraz
5.10.2018 17:12 /
Jakub Kuljovsky
Re: Jaký kurz a software by jste doporučili pro začínajcího kodéra?