关于尝试开发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


代码如下:

/*
  +----------------------------------------------------------------------+
  | 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.
*/

#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);

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

// sleep(1);

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;

测试结果:

(0)

相关推荐

  • 初步介绍PHP扩展开发经验分享

    环境:PHP 5.2.14 CentOS 5.5 第一步:建立扩展骨架 cd php-5.2.14/ext ./ext_skel –extname=laiwenhui 第二步:修改编译参数 cd php-5.2.14/ext/laiwenhui vi config.m4 去掉 PHP_ARG_ENABLE(laiwenhui, whether to enable laiwenhui support, [ --enable-laiwenhui Enable laiwenhui support])

  • Windows环境下PHP开发环境搭建 - 图文完全教程

    基于Windows环境下的PHP开发环境搭建 (apache+mysql+php) 一.准备工作 Apache2.2.11 下载地址:http://www.apache.org MySQL5.0 下载地址:http://www.mysql.com PHP5.2.9 下载地址:http://www.php.net 二.配置PHP 1. 将php-5.2.9-win32.zip解压缩到指定位置(如C:\ ),并将其改为php[如下图] 2.打开php文件夹,并将php.ini-dist更名为php.

  • 快速开发一个PHP扩展图文教程

    需求:比如开发一个叫做 heiyeluren 的扩展,扩展里就一个函数 heiyeluren_test(),输入一个字符串,函数返回:Your input string: xxxxx. 要求:了解C/C++编程,熟悉PHP编程 环境:下载一份php对应版本的源码,我这里是 php-5.2.6,先正常安装php,假设我们的php安装在 /usr/local/php 目录,源码在 /root/soft/php/php-5.2.6/,现在开始!步骤一:生成扩展框架 cd /root/soft/php/

  • PHP内核介绍及扩展开发指南—基础知识

    一. 基础知识 本章简要介绍一些Zend引擎的内部机制,这些知识和Extensions密切相关,同时也可以帮助我们写出更加高效的PHP代码. 1.1 PHP变量的存储 1.1.1 zval结构 Zend使用zval结构来存储PHP变量的值,该结构如下所示: 复制代码 代码如下: typedef union _zvalue_value { long lval; /* long value */ double dval; /* double value */ struct { char *val;

  • windows下配置php5.5开发环境及开发扩展

    网上的教程是比较多的,但是我发现在windows下的扩展开发比较少,而且大多都是php5.3版本以前的,今天我就给大家讲解一下php扩展开发,我就拿php5.5的版本来说明一下的了 windows环境(我个人的) 复制代码 代码如下: windows 8.1 企业版(mac os Boot Camp安装的) Visual Studio 2012 版本 msysgit  (http://msysgit.github.io/ 下载) php-sdk-binary-tools-20110915.zip

  • Windows下搭建PHP开发环境(Apache+PHP+MySQL)

    PHP集成开发环境有很多,如XAMPP.AppServ......只要一键安装就把PHP环境给搭建好了.但这种安装方式不够灵活,软件的自由组合不方便,同时也不利于学习.所以我还是喜欢手工搭建PHP开发环境,需要哪个模块自己安装就行了,或者那个软件需要升级,直接升级那个软件就行了,并不影响其他软件,非常方便. 一.准备工作-下载所需软件 Apache  httpd-2.2.22-win32-x86-openssl-0.9.8t.msiPHP     php-5.3.10-Win32-VC9-x86

  • windows下开发并编译PHP扩展的方法

    现在就简单说一在WINDOWS下开发PHP扩展的步骤: 首先需要准备的软件有: cygwin 安装路径e:\app\cygwin visual studio C++ 6.0, 修改环境变量,把已经安装好的PHP路径设置为环境变量.在这里,假设我的PHP安装目录是:e:\app\php5.2.5,那么我把WINDOWS环境变量后面加上这个安装目录.方便一会儿使用php.exe. PHP源代码,这里假设为e:\c_source_code\php-5.2.5 1.修改文件 "PHP源文件目录/ext/

  • 关于尝试开发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);

  • PHP源码之 ext/mysql扩展部分

    我写过一个外部模块扩展,现在开始看PHP源码中的mysql扩展,它是可以被集成到PHP内部的,所以应该算是内置的扩展了. 该扩展需要用到mysql数据库提供的一些接口,所以需要安装了mysql,并能够确定mysql.h的位置. 该扩展的位置一般在 PHP-source-code/ext/mysql 下. 在linux下,主要需要注意的文件是: config.m4, php_mysql.c, php_mysql_structs.h. ps:该目录下有tags文件,所以可以利用ctags的各种特性,

  • CentOS 7下部署php7.1和开启MySQL扩展的方法教程

    前言 之前在CentOS7安装php7.1的时候有遇到PHP源及PHP7.1不支持MySQL扩展问题,上午抽空安装了下终于解决了这两个问题,特此记录备忘. 简单安装(yum方式) 安装软件源 添加epel源 [root@opstrip.com opt]# rpm --import /etc/pki/rpm-gpg/RPM-GPG-KEY* [root@opstrip.com opt]# rpm -Uvh http://mirrors.rit.edu/fedora/epel//7/x86_64/e

  • 教你使用VS Code的MySQL扩展管理数据库的方法

    我将在本文告诉你如何用VS Code的扩展程序管理MySQL数据库,包括连接到MySQL.新建数据库和表.修改字段定义.简单的查询方法以及导入导出. 在许多情况下,我们需要随时查看数据库的记录来确保程序是否正确执行.也有许多工具提供了可视化的界面来帮助我们实现这些功能,例如phpMyAdmin(需要安装PHP和Web服务器).Navicat(强大的SQL管理工具,但需要商业授权),也有一些免费的工具可以使用,如Workbench.Sequel Pro.HeidiSQL等等.当然你也可以直接使用m

  • 详解spring开发_JDBC操作MySQL数据库

    本文介绍spring开发_JDBC操作MySQL数据库,具体如下: 项目结构: 数据库表: /spring_1100_spring+jdbc/src/com/b510/bean/Person.java package com.b510.bean; /** * 普通的javaBean类Person * * @author Hongten * */ public class Person { /** * id号 */ private int id; /** * 姓名 */ private Strin

  • 安装PHP可能遇到的问题“无法载入mysql扩展” 的解决方法

    访问phpmyadmin时总是出现 "无法载入 mysql 扩展,请检查 PHP 配置".查看原因是"php_mysql.dll"无法载如. 对于php 4.x用户,按照discuz!4.0程序中的用户手册说明做一般就可以.出现这个问题最多是php 5.x的用户. 我在搭建环境时出现这个问题,想从这个论坛上查一下解决的办法,一查发现遇到这个问题的人还挺多. 因为是刚开始捣鼓php,所以各个程序就都下载现在最新的了,对于老鸟来说可能用早一点的版本习惯了,还不喜欢用最新

  • 使用Vue开发自己的Chrome扩展程序过程详解

    前言 浏览器扩展程序是可以修改和增强 Web 浏览器功能的小程序.它们可用于各种任务,例如阻止广告,管理密码,组织标签,改变网页的外观和行为等等. 好消息是浏览器扩展并不难写.可以用你已经熟悉的 Web 技术(HTML.CSS 和 JavaScript)创建 -- 就像普通网页一样.但是与网页不同的是,扩展程序可以访问许多特定于浏览器的 API,这才是有趣的地方. 在本教程中,我将向你展示如何为 Chrome 构建一个能够改变新标签页行为的简单扩展.这个扩展程序的 JavaScript 部分,我

  • PHP开发环境配置(MySQL数据库安装图文教程)

    一. MySQL的安装 运行MYSQL安装程序(mysql-essential-5.1.40-win32.msi) 选择安装类型为Custom 点选Change按钮更改安装目录 将安装目录更改为到D盘(可根据自己的系统更改) 点击Install按钮开始安装 安装程序将开始安装MySQL到指定的路径中 安装过程中汇出现一些广告点Next跳过即可. 安装完成后出现以下界面,只选择Configrue the MySQL Server now选项,然后点击Finish按钮 点击Next按钮开始配置MyS

  • phpMyAdmin“无法载入 mysql 扩展, 请检查 PHP 配置”问题的解决方案

    还有说需要复制到system32下面,一看就是歪招.终于发现有人说到对于 "PHPRC"环境变量的问题!大概是因为它吧--根据我的理解(第一次用PHP[也许是第二次],第二次[也许是第三次]用 phpMyAdmin,更别说XAMPP),PHPRC最重要的作用就是找到php.ini文件,而作为装机狂人的我之前安装过ZEND(虽然没有用过).于是发现果然ZEND设置好了PHPRC环境变量,而XAMPP安装没有修改这个设置.修改之! 等等!在XAMPP面板中重新启动Apache怎么还是不行呀

随机推荐