|  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 22130×
 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é funkceJak 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:
 
  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,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:
 
  Funkce se vytváří pomocí klauzule CREATE
FUNCTION.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.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.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.Tělo funkce musí obsahovat klíčové slovo RETURN (bez S), které vrátí výsledek. Volání funkceTakto 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 
   
 
 
|  |  
| 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ů
 28.11.2018 23:56 /František KučeraProsincový 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.cz22. 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čákLinuxDays 2018 již tento víkend, registrace je otevřená.
 Přidat komentář
 18.9.2018 23:30 /František KučeraZář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.cz20.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čeraSrpnový 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ář
 
   Více ...
  Přidat zprávičku
 
  Poslední diskuze 31.7.2023 14:13 /
Linda GrahamiPhone Services
 30.11.2022 9:32 /
Kyle McDermottHosting download unavailable
 13.12.2018 10:57 /
Jan MarešRe: zavináč
 2.12.2018 23:56 /
František KučeraSraz
 5.10.2018 17:12 /
Jakub KuljovskyRe: Jaký kurz a software by jste doporučili pro začínajcího kodéra?
 
Více ...
 |