首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > Mysql >

尝试开发PHP的MYSQL扩张

2012-11-06 
尝试开发PHP的MYSQL扩展一、前期准备开发MYSQL扩展,当然得先安装MYSQL下载mysql-essential-5.1.65-win32必

尝试开发PHP的MYSQL扩展
一、前期准备开发MYSQL扩展,当然得先安装MYSQL下载mysql-essential-5.1.65-win32
必须选上红色的选项,因为开发MYSQL扩展时,需要头文件和mysql的动态库。否则扩展无法编译成功。
这个扩展的目的主要是熟悉ZEND API,并且理解如何提供PHP API。实现的PHP API有:PHP_FUNCTION(my_mysql_connect);
PHP_FUNCTION(my_mysql_close);
PHP_FUNCTION(my_mysql_get_conn);//通过链接池获取mysql资源,这个连接池没有做自动扩容与收缩。
PHP_FUNCTION(my_mysql_select_db);//切换数据库
PHP_FUNCTION(my_mysql_ping);
PHP_FUNCTION(my_mysql_query);//执行sql,可以是SELECT或INSERT、UPDATE、DELETE等有返回值与无返回值的查询语句
PHP_FUNCTION(my_mysql_fetch_assoc);//获取返回结果集
PHP_FUNCTION(my_mysql_get_insert_id);//获取上一次执行INSERT的自增ID

二、开发思路1.通过ext_skel_win32.php(骨架工具)创建my_mysql扩展。2.使用VS2008打开my_myqsl.dsp,编辑项目属性。     2.1 切换为Release版本,默认是DEBUG版本     2.2 右键项目属性-》通配属性-》C/C++-》预处理器-》预处理器定义除去其中的ZTS=1,因为我们将编译为NTS版本。(非线程安全)     2.3 右键项目属性-》通配属性-》C/C++-》常规-》附加包含目录,新增MYSQL_ROOT\include。引入头文件搜索路径。          这样当使用#include "mysql.h"时,就不会出现搜索不到头文件的错误     2.4 右键项目属性-》通配属性-》链接器-》常规-》附加库目录,新增MYSQL_ROOT\lib\opt,编译扩展时需要链接的DLL都在其中。(另外不要忘记引入php5nts.lib的路径,这是任一扩展编译时都需要引入的)     2.5 右键项目属性-》通配属性-》链接器-》输入-》附加依赖项新增libmySQL.lib,意在编译时设定需要链接的DLL。3.新建my_mysql新的PHP资源类型。4.实现PHP API,供给PHP接口使用。5.编译扩展,拷贝生成的php_my_mysql.dll到PHP_ROOT\ext下,并修改php.ini,增加extension=ext\php_my_mysql.dll。6.编写PHP文件,调用扩展中提供的函数并调试。
@MYSQL_ROOT:表示mysql的安装路径@PHP_ROOT:表示php所在路径
三、开始编码ext\my_mysql\php_my_mysql.h




热点排行