ARCHIV |
|||||
Software (10844)
Distribuce (131)
Skripty (697)
Menu
Diskuze
Informace
|
MySQL (48) - UDFUživatelsky definované funkce jsou dalším rysem databáze MySQL, kterému se dnes podíváme na zoubek. 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:
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 $$ 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:
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 $$ 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.
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 (45) - větvení kódu uložených procedur MySQL (46) - Triggery MySQL (47) - Triggery a praxe 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 |