Windows上的MySQL UDF开发

原创 2003年05月18日 11:05:00

曾以为Windows版本的MySQL存在不能使用UDF的BUG诸提交了一个bug报告。不过
似乎发现是我搞错了,MySQL的技术支持人员给了非常完美的解答,同大家分享
一下。下边是原文回复 :)

Sorry this isn't a bug.
Below I pasted a sample I did sometime ago for another user:

Ok. Assuming you have VC++ and the source distribution and a server
running,
I will create a UDF that returns a name:

Note: the sample is ugly, but the purpose here is to show you how
to handle the UDF.

- Open the mysqld.dsw workspace.
- Add New project to the workspace
- Project name: my_udf
- Select Win32 Dynamic-Link Library
- Click OK
- Select An Empty DLL project
- Click Finish
- Click OK
- Add a new file called my_udf.cpp to the project:

#include <stdlib.h>
#include <winsock.h>
#include <mysql.h>

extern "C" {
char *my_name(UDF_INIT *initid, UDF_ARGS *args, char *is_null,
       char *error);
}

char *my_name(UDF_INIT *initid, UDF_ARGS *args, char *is_null,
       char *error)
{
    char * me = "my name";

    return me;
}

- Type Ctrl+N for to create a new file.
- Select text type
- File name: my_udf.def
- Edit the above file with the below contents:
LIBRARY         UDF_EXAMPLE
DESCRIPTION             'Example Using UDF with VC++'
VERSION         1.0
EXPORTS
        my_name

- Right Click the my_udf project and select Settings
- Click the C/C++ tab
- Select General in the Category Combo
- Add the macro HAVE_DLOPEN to the PreProcessor definition
- Select Preprocessor in the Category Combo
- Add the include path to the text box: Additional Include directories
  e.g: ../include
- Press F7 for to build the DLL.

- Copy the my_udf.dll to the environment path directory:
  /winnt/system32 for example.

- Start the mysql client and issue:

C:/mysql-udf/bin>mysql -uroot -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or /g.
Your MySQL connection id is 2 to server version: 3.23.52-max-nt

Type 'help;' or '/h' for help. Type '/c' to clear the buffer.

mysql> CREATE FUNCTION my_name RETURNS STRING SONAME "my_udf.dll";
Query OK, 0 rows affected (0.08 sec)

mysql> select my_name();

mysql> drop function my_name;
Query OK, 0 rows affected (0.00 sec)

画蛇添足的作下简要中文说明。

抱歉,这并不是一个bug。下面我粘贴一个以前为某个客户做的简例,假设你有了
VC++,源码分发,并且有一个正常运行的MySQL服务器。

我将创建一个UDF它将一个名字:
注意:例子非常简陋,目的是让你了解该如何处理手头的UDF。

- 打开 mysqld.dsw 工作区。
- 添加新项目到这个工作区
- Project name: my_udf            // 项目名称:my_udf
- 选择 Win32 Dynamic-Link Library // Win32动态连接库
- 点击 OK
- 选择 An Empty DLL project       // 一个空DLL项目
- 点击 Finish
- 点击 OK
- 添加新文件 my_udf.cpp 到项目中:
#include <stdlib.h>
#include <winsock.h>
#include <mysql.h>

extern "C" {
char *my_name(UDF_INIT *initid, UDF_ARGS *args, char *is_null,
       char *error);
// 兼容C
}

char *my_name(UDF_INIT *initid, UDF_ARGS *args, char *is_null,
       char *error)
{
    char * me = "my name";

    return me;
    // 调用此UDF将返回 my name
}
- 按 Ctrl+N 来创建一个新文件。
- 选择 text 类型
- File name: my_udf.def file://文件名:my_udf.def
- 按照下边的内容编辑文件。
LIBRARY         UDF_EXAMPLE
DESCRIPTION             'Example Using UDF with VC++'
VERSION         1.0
EXPORTS
        my_name

- 右击my_udf项目并选择Settings
- 点 C/C++ 选项卡
- 选择 General
- 添加宏 HAVE_DLOPE 到预处理器定义
- 选择 Preprocessor
- 添加头文件路径: Additional Include directories
  例如: ../include
- 按 F7 去编译成 DLL.

- 复制 my_udf.dll 到环境变量path定义过的目录
  比如 /winnt/system32 。

- 打开mysql客户端

C:/mysql-udf/bin>mysql -uroot -p
Enter password:
Welcome to the MySQL monitor.  Commands end with ; or /g.
Your MySQL connection id is 2 to server version: 3.23.52-max-nt

Type 'help;' or '/h' for help. Type '/c' to clear the buffer.

mysql> CREATE FUNCTION my_name RETURNS STRING SONAME "my_udf.dll";
Query OK, 0 rows affected (0.08 sec)

mysql> select my_name();

mysql> drop function my_name;
Query OK, 0 rows affected (0.00 sec)


ok!欢迎大家来MySQL板交流UDF设计经验!我的电子邮件是HeartIcy@163.com
手机13706410308。同时,我们MySQL板准备开始系统化持续性翻译MySQL文档,
希望大家多多支持共同完成这一项目。

HeartIcy
2003年5月17日于中国济南

windows下编写mysql UDF函数的失败经历,与ubuntu下的成功编译经历

一、第一个demo 参照http://www.cnblogs.com/raker/p/4377343.html 实际运行时,出现了2点问题: 1、使用了VisualStudio,链接includ...
  • watch_ch
  • watch_ch
  • 2017年01月04日 09:39
  • 467

MySQL 利用UDF执行命令

UDF即User-Defined Functions lib_mysqludf_sys 在github的介绍: A UDF library with functions to interact ...
  • x728999452
  • x728999452
  • 2016年09月02日 14:56
  • 3318

MySQL的UDF

最近用到MySQL的UDF, 查了一下相关文献, 对用户用户实现function和Aggregate function的方法做个介绍....
  • shaoyiwenet
  • shaoyiwenet
  • 2016年11月21日 09:14
  • 2838

为 MySQL 增加 HTTP/REST 客户端:MySQL UDF 函数 mysql-udf-http 1.0 发布

Mysql-udf-http 是一款简单的MySQL用户自定义函数(UDF, User-Defined Functions),具有http_get()、http_post()、http_put()、h...
  • stary1
  • stary1
  • 2016年05月16日 21:06
  • 2067

MySQL使用UDF调用shell脚本

在最近的项目中,由于需要使用MySQL的UDF(user defined function),这个特性从未使用过,而且个人觉得这个特性以后应该会经常使用,所以写下博文,记录和分享这个特性的用法。 UD...
  • jssg_tzw
  • jssg_tzw
  • 2017年06月14日 15:20
  • 632

MySQL使用udf调用系统程序

需要在mysql里调用系统程序执行,这个功能mysql默认不提供,但可以通过定义udf(自定义函数)实现。好在开源社区里已经有人为我们实现这个程序了。 1.下载lib_mysqludf_sys程...
  • mypcstyle
  • mypcstyle
  • 2014年07月07日 15:05
  • 6063

Mysql安装udf调用系统程序问题解决

安装udf调用系统程序,在使用编译出的lib_mysqludf_sys.so遇到了 1. failed:FUNCTION ramsdb.sys_exec does not exist! 2. E...
  • u010543785
  • u010543785
  • 2016年12月05日 18:05
  • 1535

Mysql_UDF提权

Root权限一、上传udf.dll小于mysql5.1版本 C:\WINDOWS\udf.dll 或 C:\WINDOWS\system32\udf.dll 等于mysql5.1版本 ...
  • WuLex
  • WuLex
  • 2017年02月04日 23:27
  • 5459

MySQL 加载UDF(自定义函数)

我们神一样的研发这几天抱怨mysql提供的功能太少,然后就动手自己写UDF并加载到mysql中。 至于神马是MYSQL UDF 以及作用可详见:http://dev.mysql.com/doc/re...
  • lidan3959
  • lidan3959
  • 2013年12月11日 16:14
  • 1765

编写MYSQL插件(UDF)使其实现Split函数

.
  • Sidyhe
  • Sidyhe
  • 2016年01月19日 16:12
  • 1276
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Windows上的MySQL UDF开发
举报原因:
原因补充:

(最多只允许输入30个字)