我们神一样的研发这几天抱怨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,此文件保存已排好序的动态链接库名字列表]
好不容易清闲一天,就先写到这吧!