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

> 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.

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

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í toku

Prakticky 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ódu

Podmí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');
insert into log values ('20051103081525', '10.1.1.2');
insert into log values ('20051103074838', '192.168.36.3');
insert into log values ('20051103091319', '10.0.0.9');
insert into log values ('20051103073859', '127.0.0.1');
insert into log values ('20051103072518', '65.50.48.206');

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)
begin
  if jennejnovejsich5=1 then
    select * from log order by datum desc limit 5;
  else
    select * from log order by datum desc;
  end if;
end

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))
begin
  if exists(select * from software where id = radek) then
    update software set nazev = novynazev where id = radek;
  else
    insert into software (id, nazev) values (radek, novynazev);
  end if;
end

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');
call sp_vlozneboaktualizuj(10,'žádný 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ínkou

Se 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()
begin
  declare den date;
  set den = curdate();
  create temporary table dny (datum date);
  while den < (curdate() + interval 30 day) do
    insert into dny (datum) values (den);
    set den = den + interval 1 day;
  end while;
  select datum from dny;
end

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.

Verze pro tisk

pridej.cz

 

DISKUZE

PL/SQL na linuxu 5.11.2005 09:23 mrzout
L Re: PL/SQL na linuxu 6.11.2005 11:16 Petr Vaněk
replace into 5.11.2005 18:00 Adam Skalík
  L Re: replace into 6.11.2005 09:48 Petr Zajíc




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

15.1.2018 0:51 /František Kučera

První letošní pražský sraz se koná již tento čtvrtek 18. ledna od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5). Vítáni jsou všichni příznivci svobodného softwaru a hardwaru, ESP32, DIY, CNC, SDR nebo dobrého piva. Prvních deset účastníků srazu obdrží samolepku There Is No Cloud… just other people's computers. od Free Software Foundation.


Přidat komentář

14.11.2017 16:56 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt – tradičně první čtvrtek před třetím pátkem v měsíci: 16. listopadu od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

12.11.2017 11:06 /Redakce Linuxsoft.cz
PR: 4. ročník odborné IT konference na téma Datová centra pro business proběhne již ve čtvrtek 23. listopadu 2017 v konferenčním centru Vavruška, v paláci Charitas, Karlovo náměstí 5, Praha 2 (u metra Karlovo náměstí) od 9:00. Konference o návrhu, budování, správě a efektivním využívání datových center nabídne odpovědi na aktuální a často řešené otázky, např Jaké jsou aktuální trendy v oblasti datových center a jak je využít pro vlastní prospěch? Jak zajistit pro firmu či jinou organizaci odpovídající služby datových center? Podle jakých kritérií vybrat dodavatele služeb? Jak volit součásti infrastruktury při budování či rozšiřování vlastního datového centra? Jak efektivně spravovat datové centrum? Jak eliminovat možná rizika? apod.
Přidat komentář

13.9.2017 8:00 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt – tentokrát netradičně v pondělí: 18. září od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

3.9.2017 20:45 /Redakce Linuxsoft.cz
PR: Dne 21. září 2017 proběhne v Praze konference "Mobilní řešení pro business". Hlavní tématy konference budou: nejnovější trendy v oblasti mobilních řešení pro firmy, efektivní využití mobilních zařízení, bezpečnostní rizika a řešení pro jejich omezení, správa mobilních zařízení ve firmách a další.
Přidat komentář

15.5.2017 23:50 /František Kučera
Máš rád svobodný software a hardware nebo se o nich chceš něco dozvědět? Zajímá tě DIY, CNC, SDR nebo morseovka? Přijď na sraz spolku OpenAlt, který se bude konat ve čtvrtek 18. května od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

12.5.2017 16:42 /Honza Javorek
PyCon CZ, česká konference o programovacím jazyce Python, se po dvou úspěšných ročnících v Brně bude letos konat v Praze, a to 8. až 10. června. Na konferenci letos zavítá např. i Armin Ronacher, známý především jako autor frameworku Flask, šablon Jinja2/Twig, a dalších projektů. Těšit se můžete na přednášky o datové analytice, tvorbě webu, testování, tvorbě API, učení a mentorování programování, přednášky o rozvoji komunity, o použití Pythonu ve vědě nebo k ovládání nejrůznějších zařízení (MicroPython). Na vlastní prsty si můžete na workshopech vyzkoušet postavit Pythonem ovládaného robota, naučit se učit šestileté děti programovat, efektivně testovat nebo si v Pythonu pohrát s kartografickým materiálem. Kupujte lístky, dokud jsou.
Přidat komentář

2.5.2017 9:20 /Eva Rázgová
Putovní konference československé Drupal komunity "DrupalCamp Československo" se tentokrát koná 27. 5.2017 na VUT FIT v Brně. Můžete načerpat a vyměnit si zkušenosti z oblasti Drupalu 7 a 8, UX, SEO, managementu týmového vývoje, využití Dockeru pro Drupal a dalších. Vítáni jsou nováčci i experti. Akci pořádají Slovenská Drupal Asociácia a česká Asociace pro Drupal. Registrace na webu .
Přidat komentář

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

> Poslední diskuze

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

31.8.2017 12:11 / Jaromir Obr
Re: ukůládání dat ze souboru

30.7.2017 11:12 / Jaromir Obr
Národní znaky

Více ...

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