ARCHIV |
|||||
Software (10844)
Distribuce (131)
Skripty (697)
Menu
Diskuze
Informace
|
MySQL (45) - větvení kódu uložených procedur... aneb kterak v uložených procedurách MySQL využít podmínky a smyčky. Samozřejmě, že uložené procedury nemusejí obsahovat jen sadu
příkazů, které se budou sekvenčně provádět od jednoho k druhému. Mohou
obsahovat určité příkazy pro větvení kódu, jako jsou smyčky nebo
podmínky. To dnes prozkoumáme; takové věci totiž dělají z uložených
procedur docela užitečné pomocníky. Alespoň v některých situacích. Řízení tokuPrakticky jakýkoli programovací jazyk má nějaké ty příkazy pro
řízení toku programu. Patří sem nejrůznější podmínkové konstrukce,
smyčky, odskoky na návěští a podobně. Jazyk pro uložené procedury v
MySQL má něco podobného, i když je to jen slabý odvar toho, co možná
znáte z jazyků jako C nebo JAVA. Nicméně programování uložených procedur může bý pro ná mnohem
jednodušší, jestliže takové konstrukce známe; já se dnes zaměřím na ty
nejpoužívanější z nich, a to jsou podmínky a smyčky. Podmíněné provádění kóduPodmínky jsou asi nejčastější používanou konstrukcí pro větvení kódu, alespoň v procedurách. Umožňují nám provést nebo neprovést jistou část kódu na základě splnění nebo nesplnění podmínky. Ilustrujme to na jednoduchém příkladu. Vytvoříme si tabulku obsahující protokolování návštěv na našem serveru: create table log (datum
datetime, ip varchar (15));
a naplníme ji nějakými hypotetickými daty (jsou to samozřejmě jen příklady) insert into log values
('20051103072516', '10.1.1.0');
Jak napsat uloženou proceduru, která vrátí všechny záznamy z této tabulky, nebo jen prvních pět? S použitím podmínky je to hračka: create procedure
sp_showlog (jennejnovejsich5 boolean)
Jak vidíte, je to celkem snadno pochopitelné. Fantazii se meze
nekladou, namísto logické hodnoty obsahující údaj o tom, zda chceme
vrátit prvních pět záznamů nebo rovnou všechny může vstupní parametr
obsahovat přímo údaj o tom, kolik řádků chceme vrátit a podobně.
Vracení různých sad záznamů na základě hodnot parametrů je dosti častým
příkladem použití podmínek uvnitř těla procedur. Nejsme však vázáni pouze na takové použití. Tatáž uložená procedura může jednou provádět vložení záznamů a jindy jeho aktualizaci. Ukažme to opět na příkladu: create procedure
sp_vlozneboaktualizuj (radek int, novynazev varchar(50))
Tato procedura vykonává dosti fikanou úlohu - buď řádek najde a aktualizuje, nebo jej vloží. Něco takového byste pomocí kódu na straně klienta zcela jistě neudělali tak jednoduše jako zde pomocí uložené procedury. Můžete si zkusit tuto procedutu spusti dvakrát: call
sp_vlozneboaktualizuj(10,'test');
a uvidíte, že řádek je poprvé vložen a podruhé zaktualizován.
Procedury tohoto typu můžete v praxi vidět například při ukládání
konfiguračních hodnot do databáze - buď již záznam s kofigurací
existuje a je použit, nebo neexistuje a je vytvořen. Smyčky s podmínkouSe smyčkami se sice v uložených procedurách nesetkáváme zdaleka tak
často jako s podmínkami, ale je dobré o nich něco vědět. Smyčky nám
umožňují provádět opakovaně nějaký kód dokud platí podmínka (to jsou
smyčky s podmínkou na začátku) nebo tak dlouho, dokud po provedení
smyčky podmínka neplatí (to jsou smyčky s podmínku na konci). V
uložených procedurách se nejspíš setkáte se smyčkami s podmínku na
začátku. Jejich výsledky se často ukládají do dočasných tabulek a
později se využívají jako výstup nebo se dále zpracovávají. Ukažme si opět něco takového na příkladu. Dejme tomu, že budete potřebovat (snad pro nějakou kalendářovou aplikaci) tabulku obsahující 30 následujících dnů. Se znalostí podmínek, dočasných tabulek a uložených procedur na to můžete jít nějak takhle: create procedure
spkalendar()
Všimněte si, jak to celé funguje. Nejprve je vytvořena prázdná
dočasná tabulka a je zjištěno dnešní datum. Pak je ve smyčce WHILE
přičteno postupně 30 dnů a výsledky jsou průběžně ukládány do dočasné
tabulky. Nakonec je obsah této dočasné tabulky vrácen jako výsledek. Jistěže MySQL podporuje i smyčky s podmínku na konci; jejich použití však zdaleka není tak časté; možná proto, že taková smyčka se vždy minimálně jednou provede.
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 (42) - ještě k transakcím MySQL (43) - Uložené procedury MySQL (44) - parametry 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 |