关于尝试开发PHP的MYSQL扩展的使用

2016-02-19 10:03 6 1 收藏

下面图老师小编要跟大家分享关于尝试开发PHP的MYSQL扩展的使用,简单的过程中其实暗藏玄机,还是要细心学习,喜欢还请记得收藏哦!

【 tulaoshi.com - 编程语言 】

一、前期准备
开发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_ROOTinclude。引入头文件搜索路径。
          这样当使用#include "mysql.h"时,就不会出现搜索不到头文件的错误
     2.4 右键项目属性-》通配属性-》链接器-》常规-》附加库目录,新增MYSQL_ROOTlibopt,编译扩展时需要链接的DLL都在其中。(另外不要忘记引入php5nts.lib的路径,这是任一扩展编译时都需要引入的)
     2.5 右键项目属性-》通配属性-》链接器-》输入-》附加依赖项新增libmySQL.lib,意在编译时设定需要链接的DLL。
3.新建my_mysql新的PHP资源类型。
4.实现PHP API,供给PHP接口使用。
5.编译扩展,拷贝生成的php_my_mysql.dll到PHP_ROOText下,并修改php.ini,增加extension=extphp_my_mysql.dll。
6.编写PHP文件,调用扩展中提供的函数并调试。

@MYSQL_ROOT:表示mysql的安装路径
@PHP_ROOT:表示php所在路径

三、开始编码
extmy_mysqlphp_my_mysql.h
代码如下:

/*
  +----------------------------------------------------------------------+
  | PHP Version 5                                                        |
  +----------------------------------------------------------------------+
  | Copyright (c) 1997-2012 The PHP Group                                |
  +----------------------------------------------------------------------+
  | This source file is subject to version 3.01 of the PHP license,      |
  | that is bundled with this package in the file LICENSE, and is        |
  | available through the world-wide-web at the following url:           |
  | http://www.php.net/license/3_01.txt                                  |
  | If you did not receive a copy of the PHP license and are unable to   |
  | obtain it through the world-wide-web, please send a note to          |
  | license@php.net so we can mail you a copy immediately.               |
  +----------------------------------------------------------------------+
  | Author:                                                              |
  +----------------------------------------------------------------------+
*/

/* $Id$ */

#ifndef PHP_MY_MYSQL_H
#define PHP_MY_MYSQL_H

extern zend_module_entry my_mysql_module_entry;
#define phpext_my_mysql_ptr &my_mysql_module_entry

#ifdef PHP_WIN32
# define PHP_MY_MYSQL_API __declspec(dllexport)
#elif defined(__GNUC__) && __GNUC__ = 4
# define PHP_MY_MYSQL_API __attribute__ ((visibility("default")))
#else
# define PHP_MY_MYSQL_API
#endif

#ifdef ZTS
#include "TSRM.h"
#endif

PHP_MINIT_FUNCTION(my_mysql);
PHP_MSHUTDOWN_FUNCTION(my_mysql);
PHP_RINIT_FUNCTION(my_mysql);
PHP_RSHUTDOWN_FUNCTION(my_mysql);
PHP_MINFO_FUNCTION(my_mysql);

PHP_FUNCTION(my_mysql_connect);
PHP_FUNCTION(my_mysql_close);

PHP_FUNCTION(my_mysql_get_conn);
PHP_FUNCTION(my_mysql_select_db);
PHP_FUNCTION(my_mysql_ping);
PHP_FUNCTION(my_mysql_query);
PHP_FUNCTION(my_mysql_fetch_assoc);
PHP_FUNCTION(my_mysql_get_insert_id);

/*
   Declare any global variables you may need between the BEGIN
 and END macros here:    
*/
ZEND_BEGIN_MODULE_GLOBALS(my_mysql)
 long  max_connection;
  long  default_connection;
 char *driver_name;

  char *host;
  char *pwd;
  char *user;
  long port;
ZEND_END_MODULE_GLOBALS(my_mysql)

/* In every utility function you add that needs to use variables
   in php_my_mysql_globals, call TSRMLS_FETCH(); after declaring other
   variables used by that function, or better yet, pass in TSRMLS_CC
   after the last function argument and declare your utility function
   with TSRMLS_DC after the last declared argument.  Always refer to
   the globals in your function as MY_MYSQL_G(variable).  You are
   encouraged to rename these macros something shorter, see
   examples in any other php module directory.
*/

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

#ifdef ZTS
#define MY_MYSQL_G(v) TSRMG(my_mysql_globals_id, zend_my_mysql_globals *, v)
#else
#define MY_MYSQL_G(v) (my_mysql_globals.v)
#endif

#endif /* PHP_MY_MYSQL_H */

接口测试test.php
代码如下:

?php

// $mysql = my_mysql_connect("localhost", "root", "", "test", 3306);
// var_dump($mysql);
// // my_mysql_close($mysql);

// sleep(10);
$conn = array();
$conn[] = my_mysql_get_conn();
$conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();

// $conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();

// $conn[] = my_mysql_get_conn();
// $conn[] = my_mysql_get_conn();
// print_r($conn);

var_dump($conn[0]);

// my_mysql_select_db($conn[0], "test");

// mysql_query("show processlist", $conn[0]);
// print_r($status);

// sleep(1);

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

my_mysql_select_db($conn[0], "mysql");

// sleep(1);

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

my_mysql_select_db($conn[1], "test");

my_mysql_ping($conn[1]);

$result = my_mysql_query($conn[1], "select * from test");

var_dump($result);

$arr = my_mysql_fetch_assoc($result);

my_mysql_query($conn[1], "INSERT INTO test VALUES(id, 'abc')");

$insert_id = my_mysql_get_insert_id($conn[1]);

print_r($arr);

echo $insert_id;

测试结果:

来源:http://www.tulaoshi.com/n/20160219/1593199.html

延伸阅读
标签: PHP
安装 Zend Studio 双击 ZendStudio-x.exe 文件开始安装 Zend Stuido 客户端,,如下图:   一路 Next 并同意许可协议。选择安装路径时按照默认位置安装。当到选择安装组件的时候选中 Zend Studio Server。确保你已经连接上互联网了,点 Next ,如下图:   开始下载这两个软件,如果需要使用代理连接,可以按...
标签: PHP
  Zend Server Center 的使用:   点击 ZDE 工具栏里的 Zend Server Center 图标: 或者在浏览器中输出: / 后回车,将会打开 Zend Studio 的 Web 登录页面: 这里就包括了 Zend Server Center 和 Zend Information Center 两个部分。后者包含更详细的 Zend Studio 的使用功能介绍。 点击 Zend Server C...
标签: PHP
  PHP与MySQL交互使用详解 1、创建自动连接数据库的代码,并生成一些必要的代码.我们仔细研究一下数据库的连接函数,会发现是这样的一行代码。 $link_id=@mysql_connect($hostname,$username,$password); 所以我们在include文件connect.inc中添加以下代码就可以了。connect.inc<?php$hostname='localhost'; $username='phpstar';$pa...
标签: PHP
PHP 让很多初学者却步的原因是相对复杂的 PHP 调试环境的建立,PHP 的测试环境是学习 PHP 首要解决的问题。所以,本文就以解决这个首要问题为开端。PHP 环境配置是很灵活的,这里我就按照更适合于学习的安装方法来讲解。我在开篇里想说的是,安装 PHP 环境没有想象的那么难,其实当你多装几次以后,就会发现安装 PHP 真的很容易。...
标签: PHP
选择哪一种服务器,IIS 还是 Apache? 到这里就有两种选择了,到底选择 IIS 还是 Apache 呢?我看还是看个人的喜好吧,如果你想让你的服务器也支持 ASP,那么就选择 IIS,如果你已经安装了 IIS,那么也可以直接使用 IIS,不过这两个服务器最好只装一个,否则端口将会冲突(当然也可以设置这两个 Web Server 使用不同端口)。我先...

经验教程

554

收藏

77
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部