MySQLのユーザー定義関数(UDF)は大昔に作った記憶があるけど、最近作ってなかったので試しに作ってみたメモ。
関数の中身はなんでも良かったんだけど、フィボナッチ数を求める fib()を作ってみた。
ちゃんと知りたい場合は、マニュアルとかサンプルプログラムを見ましょう。
% gcc -shared -I /usr/local/mysql/include fib.c -o fib.so % sudo cp fib.so /usr/local/mysql/lib/plugin/ % /usr/local/mysql/bin/mysql -uroot mysql> create function fib returns integer soname 'fib.so'; Query OK, 0 rows affected (0.02 sec) mysql> select n, fib(n) from (values row(1),row(2),row(3),row(4),row(5),row(6),row(7),row(8),row(9),row(10)) as n(n); +----+--------+ | n …[さらに読む]