现在的位置: 首页 > 综合 > 正文

MySQL 加载UDF(自定义函数)

2018年01月21日 ⁄ 综合 ⁄ 共 1415字 ⁄ 字号 评论关闭

我们神一样的研发这几天抱怨mysql提供的功能太少,然后就动手自己写UDF并加载到mysql中。

至于神马是MYSQL UDF 以及作用可详见:http://dev.mysql.com/doc/refman/5.5/en/adding-functions.html

这里顺便就记录一下操作过程:

其中链接库名:lib_mysqludf_json.so (作用是解析数据库中存放的json数据)

1,上传链接库到服务器 ... ...  (如果有备库,备库也得一样)

2,修改属主和授可执行权限

 chown mysql:mysql /home/lidan/lib_mysqludf_json.so 
 chmod u+x /home/lidan/lib_mysqludf_json.so 

3,拷贝到mysql 的lib目录下

如果不清楚mysql lib目录可以登mysql执行


mysql> show variables like '%plug%';
+---------------+-------------------------+
| Variable_name | Value                   |
+---------------+-------------------------+
| plugin_dir    | /usr/lib64/mysql/plugin |
+---------------+-------------------------+

然后拷贝

 cp -p /home/lidan/lib_mysqludf_json.so  /usr/lib64/mysql/plugin/
然后执行 

ldconfig (非必须) ***

最后登陆mysql创建自定义函数:(如果是主从环境,这一步只需要在主库执行即可)

    create function lib_mysqludf_json_info returns string soname 'lib_mysqludf_json.so';
    create function json_array returns string soname 'lib_mysqludf_json.so';
    create function json_members returns string soname 'lib_mysqludf_json.so';
    create function json_object returns string soname 'lib_mysqludf_json.so';
    create function json_values returns string soname 'lib_mysqludf_json.so';

注意,如果库中没有相关的函数者会报错如:

 CREATE FUNCTION json_get RETURNS STRING SONAME 'lib_mysqludf_json.so';
  ERROR 1127 (HY000): Can't find symbol 'json_get' in library

*** : ldconfig  命令的用途,主要是在默认搜寻目录(/lib和/usr/lib)以及动态库配置文件/etc/ld.so.conf内所列的目录下,搜索出可共享的动态 链接库(格式如前介绍,lib*.so*),进而创建出动态装入程序(ld.so)所需的连接和缓存文件.缓存文件默认为  /etc/ld.so.cache,此文件保存已排好序的动态链接库名字列表]

好不容易清闲一天,就先写到这吧!

抱歉!评论已关闭.