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

> MySQL (48) - UDF

Uživatelsky definované funkce jsou dalším rysem databáze MySQL, kterému se dnes podíváme na zoubek.

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

Komerční sdělení: Pořádáme Kurzy MySQL

Protože jsme se v tomto seriálu již začali věnovat novým rysům MySQL 5.0, jako jsou uložené procedury a spouště, slušelo by se rovněž zmínit se o uživatelsky definovaných funkcích. Ty byly totiž rovněž přidány v poslední době - a i s nimi je databázový život mnohem jednodušší. Pojďme se tedy podívat, co nám v tomto ohledu může MySQL nabídnout.

Uživatelsky definované funkce

Jak jste asi pochopili, uživatelsky definovaná funkce je taková, kterou si můžete sami napsat. V tomto ohledu by z hlediska MySQL mohlo dojít k určitému matení pojmů, v tomto systému si totiž můžete napsat vlastní funkci dvěma způsoby:

  1. Jednak můžete rozšířit databázový systém napsáním rutiny v jazycích C či C++ a tuto rutinu pak zaregistrovat pro použití na serveru,
  2. a jednak můžete (od verze 5.0.3) vytvářet uživatelsky definované funkce pomocí příkazu SQL - CREATE FUNCTION.

My se dnes budeme bavit pouze o tom druhém způsobu, a sice o vytváření funkcí pomocí příkazu CREATE FUNCTION. Tyto funkce se v mnohém podobají uloženým procedurám - například v tom, že mohou požadovat vstupní parametry nebo v tom, že jsou svázány s konkrétní databází. Než bych to dlouze vysvětloval, raději posloužím nějakým názorným příkladem. Je to odpověď na otázku, kterou často dostávám e-mailem: zda a jak se dá zajistit, aby MySQL vracela české datumy s textovým označením měsíce.

My na to půjdeme tak, že si vytvoříme funkci, která podle pořadového čísla měsíce "natvrdo" vrátí jeho textovou reprezentaci (ve druhém pádě). Jak bude tato funkce vypadat? Nějak takhle:

delimiter $$
create function mesicslovy (mesic tinyint)
returns varchar (9)
begin
return
case mesic
  when 1 then 'ledna'
  when 2 then 'února'
  when 3 then 'března'
  when 4 then 'dubna'
  when 5 then 'května'
  when 6 then 'června'
  when 7 then 'července'
  when 8 then 'srpna'
  when 9 then 'září'
  when 10 then 'října'
  when 11 then 'listopadu'
  when 12 then 'prosince'
end;
end $$
delimiter ;

Jak vidíte, je tvorba uživatelských funkcí v MySQL velmi prostá. Je ale přitom třeba mít na paměti následující zásady:

  1. Funkce se vytváří pomocí klauzule CREATE FUNCTION.
  2. Funkce může (ale pochopitelně nemusí) přijímat vstupní parametry. Těch může být jedna a více - ale je třeba určit jejich typ.
  3. Dále je třeba určit, jaký datový typ bude naše milá funkce vracet. To se provede pomocí klíčového slova RETURNS. Pozor, na konci je S.
  4. Pak následuje tělo funkce, ohraničené pomocí bloku BEGIN a END tak, jako je tomu u uložených procedur. Všimněte si, že v našem případě je tělo funkce tvořeno jediným příkazem; samozřejmě to není podmínka.
  5. Tělo funkce musí obsahovat klíčové slovo RETURN (bez S), které vrátí výsledek.

Volání funkce

Takto vytvořená funkce je pochopitelně k ničemu, pokud ji nebudeme z kódu volat. Pro volání uživatelem vytvořených funkcí přitom platí jednoduché pravidlo: volají se stejně jako funkce vestavěné. Jinými slovy systém se chová tak, jako by v něm naše drahá funkce byla odjakživa. Pokud tedy napíšete:

select mesicslovy(5);

Dostanete kýžený výsledek ("května"). Samozřejmě, že jedna funkce může volat funkci jinou:

delimiter $$
create function ceskedatum (datum date)
returns varchar (18)
begin
  return
  CONCAT(
    day(datum),
    '. ',
    mesicslovy (month(datum)),
    ' ',
    year(datum)
  );
end $$
delimiter ;

Můžete si to vyzkoušet: Stačí zavolat něco ve smyslu:

select ceskedatum(now());

a hned obdržíte hezkou českou reprezentaci data přímo z MySQL. Výhoda je jasná - pokud bude databázi využívat více různých klientů - možná napsaných v různých programovacích jazycích - všichni můžou těžit z této funkce uložené na serveru. A ještě jedna poznámka: při testech jsem si všiml, že MySQL standardně přetypovává vstupní parametry funkcí na ten datový typ, který funkce očekává. Prakticky to znamená, že následující příkaz PROJDE:

select ceskedatum('2005-12-24');

Funkce očekávala datum, ale dostala řetězec. Ten se pokusila převést na datum, což se povedlo a tak se celý příkaz v tichosti dokončil. Nejsem si tak úplně jistý, jestli je to dobře nebo špatně, ale pohodlné to každopádně je.

Použití funkcí

Přestože se funkcemi dá ošetřit leccos, měli byste je v MySQL používat spíše střízlivě. Do určité verze MySQL nesměly funkce obsahovat odkazy na tabulky, a i v současné době mají jistá omezení. "Správná" databázová funkce by tedy měla být krátká, měla by řešit pouze jeden problém a to problém související s daty. Pěkným příkladem mohou být právě funkce sloužící k formátování výstupu.

Verze pro tisk

pridej.cz

 

DISKUZE

Nejsou žádné diskuzní příspěvky u dané položky.



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

8.5.2016 17:19 /Redakce Linuxsoft.cz
PR: Dne 26.5.2016 proběhne v Praze konference Cloud computing v praxi. Tématy bude např. nejnovější trendy v oblasti cloudu a cloudových řešení, cloudové služby, infrastruktura cloudu, efektivní využití cloudu, možné nástrahy cloudů a jak se jim vyhnout
Přidat komentář

21.4.2016 8:01 /František Kučera
Spolek OpenAlt zve na 127. distribuovaný sraz příznivců svobodného softwaru a otevřených technologií (hardware, 3D tisk, SDR, DIY, makers…), který se bude konat ve čtvrtek 28. dubna od 18:00 v Radegastovně Perón (Stroupežnického 20, Praha 5).
Přidat komentář

2.3.2016 22:41 /Ondřej Čečák
Letošní ročník konference InstallFest již tento víkend!
Přidat komentář

14.2.2016 16:39 /Redakce Linuxsoft.cz
O víkendu 5. a 6. března 2016 proběhne na pražském Strahově 8. ročník tradiční konference InstallFest. Celkem za dva dny uvidíte ​30 přednášek​ a ​6 workshopů.
Přidat komentář

5.2.2016 17:38 /Petr Ježek
Utilitka z XFce "xfce4-power-manager" nejen umožňuje nastavení lhůty pro uspání či hybernaci, ale i zapínání a vypínání prezentačního módu pro nerušené sledování videí. Stačí ji nastavit v každém vybavenějším panelu a v jakémkoli nontiled WM/DE.
Přidat komentář

10.1.2016 11:32 /Pavel `Goldenfish' Kysilka
LinuxMarket změnil provozovatele. Nově jej provozuje Marek Pszczolka. Více info a detaily #1 a #2.
Přidat komentář

29.12.2015 11:38 /Ondřej Čečák
Ještě posledních pár dní můžete přidávat příspěvky nebo nápady na Install Fest 2016, který se bude konat 5. a 6. března 2016.
Přidat komentář

8.12.2015 11:36 /Petr Ježek
Logické se stává realitou. LibreOffice a Thunderbird se mají dle článku na Redditu stát protiváhou MS řešení (MS Office a Outlook).
Přidat komentář

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

> Poslední diskuze

7.5.2016 14:58 / Teodor Komárek
Soubory

20.4.2016 0:07 / Jakub Cleing
Sázkový panel PHP FUSION

9.4.2016 9:43 / jiwopene@gmail.com
Re: problém s dpkg a nemožností instalovat

9.4.2016 9:41 / jiwopene@gmail.com
Re: změna velikosti disk.oddílu

9.4.2016 9:40 / jiwopene@gmail.com
Re: Přenesení starého OS Win7 na virtuál v Debianu

Více ...

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