ARCHIV |
||||||||||||||||||||||||||||||||||
Software (10844)
Distribuce (131)
Skripty (697)
Menu
Diskuze
Informace
|
MySQL (42) - ještě k transakcímDnes si ukážeme nějaké praktické příklady transakcí. 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 transakceKaž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í:
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);
a zkusme to celé provést. Půjdeme na to takto: start transaction; 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):
Automatické transakceJe 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;
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.
Související články
Předchozí Celou kategorii (seriál) Další
MySQL (1) - pestrý svět databází
MySQL (2) - Instalujeme databázi MySQL MYSQL (3) Instalujeme MySQL podruhé MySQL (4) - něco terminologie MySQL (5) - tajuplné SQL MySQL (6) - Ukládáme řetězce MySQL (7) - hrátky s čísly MySQL (8) - Ukládání datumů MySQL (9) - Další datové typy MySQL (10) - tvorba databáze. Základy DDL MySQL (11) - vytváříme tabulky MySQL (12) - tipy k tvorbě tabulek MySQL (13) - Vkládáme data MySQL (14) - Upravujeme data MySQL (15) - Odstraňujeme data MySQL (16) - Tipy a triky k manipulaci s daty MySQL (17) - vybíráme data MySQL (18) - Filtrujeme data MySQL (19) - Řadíme data MySQL (20) - spojení více tabulek MySQL (21) - klauzule JOIN MySQL (22) - tipy a triky ke spojování tabulek MySQL (23) - relace 1:N a N:N MySQL (24) - Seskupujeme záznamy MySQL (25) - hrátky se seskupenými záznamy MySQL (26) - Poddotazy MySQL (27) - Složitější dotazy MySQL (28) - Dotazy pro pokročilé MySQL (29) - Vracení nejvyšších záznamů MySQL (30) - průběžné součty MySQL (31) - Indexy MySQL (32) - ještě k indexům MySQL (33) - Příkaz UNION MySQL (34) - větvení kódu a pivotní tabulky MySQL (35) - vestavěné funkce MySQL (36) - Regulární výrazy MySQL (37) - použití fulltextového vyhledávání MySQL (38) - Fulltext a praxe MySQL (39) - typy tabulek v MySQL MySQL (40) - další typy tabulek MySQL (41) - Transakce MySQL (43) - Uložené procedury MySQL (44) - parametry uložených procedur MySQL (45) - větvení kódu uložených procedur MySQL (46) - Triggery MySQL (47) - Triggery a praxe MySQL (48) - UDF MySQL (49) - pohledy MySQL (50) - Pohledy podruhé MySQL (51) - Metadata MySQL (52) - A co zálohování? MySQL (53) - SELECT INTO OUTFILE MySQL (54) - zálohování MySQL z webu MySQL (55) - zálohování MySQL z pohledu správce MySQL (56) - Obnova zálohovaných dat MySQL (57) - Ach, ta čeština MySQL (58) - čeština v praxi MySQL (59) - české řazení MySQL (60) - řádkový klient MySQL (61) - Oprávnění MySQL (62) - Oprávnění podruhé MySQL (63) - jemné nastavení práv MySQL (64) - nad dotazy čtenářů MySQL (65) - Ladíme server MySQL (66) - Ještě k ladění serveru MySQL - (67) MySQL (68) - Závěr MySQL (69) - Prepared Statements Předchozí Celou kategorii (seriál) Další
|
Vyhledávání software
Vyhledávání článků
28.11.2018 23:56 /František Kučera 12.11.2018 21:28 /Redakce Linuxsoft.cz 6.11.2018 2:04 /František Kučera 4.10.2018 21:30 /Ondřej Čečák 18.9.2018 23:30 /František Kučera 9.9.2018 14:15 /Redakce Linuxsoft.cz 12.8.2018 16:58 /František Kučera 16.7.2018 1:05 /František Kučera
Poslední diskuze
31.7.2023 14:13 /
Linda Graham 30.11.2022 9:32 /
Kyle McDermott 13.12.2018 10:57 /
Jan Mareš 2.12.2018 23:56 /
František Kučera 5.10.2018 17:12 /
Jakub Kuljovsky | ||||||||||||||||||||||||||||||||
ISSN 1801-3805 | Provozovatel: Pavel Kysilka, IČ: 72868490 (2003-2024) | mail at linuxsoft dot cz | Design: www.megadesign.cz | Textová verze |