麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 編程 > C > 正文

關(guān)于嘗試開(kāi)發(fā)PHP的MYSQL擴(kuò)展的使用

2020-01-26 16:19:21
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

一、前期準(zhǔn)備
開(kāi)發(fā)MYSQL擴(kuò)展,當(dāng)然得先安裝MYSQL
下載mysql-essential-5.1.65-win32

必須選上紅色的選項(xiàng),因?yàn)殚_(kāi)發(fā)MYSQL擴(kuò)展時(shí),需要頭文件和mysql的動(dòng)態(tài)庫(kù)。否則擴(kuò)展無(wú)法編譯成功。

這個(gè)擴(kuò)展的目的主要是熟悉ZEND API,并且理解如何提供PHP API。
實(shí)現(xiàn)的PHP API有:
PHP_FUNCTION(my_mysql_connect);
PHP_FUNCTION(my_mysql_close);
PHP_FUNCTION(my_mysql_get_conn);//通過(guò)鏈接池獲取mysql資源,這個(gè)連接池只是簡(jiǎn)單的自動(dòng)擴(kuò)容,并沒(méi)有收縮。
PHP_FUNCTION(my_mysql_select_db);//切換數(shù)據(jù)庫(kù)
PHP_FUNCTION(my_mysql_ping);
PHP_FUNCTION(my_mysql_query);//執(zhí)行sql,可以是SELECT或INSERT、UPDATE、DELETE等有返回值與無(wú)返回值的查詢語(yǔ)句
PHP_FUNCTION(my_mysql_fetch_assoc);//獲取返回結(jié)果集
PHP_FUNCTION(my_mysql_get_insert_id);//獲取上一次執(zhí)行INSERT的自增ID

二、開(kāi)發(fā)思路
1.通過(guò)ext_skel_win32.php(骨架工具)創(chuàng)建my_mysql擴(kuò)展。
2.使用VS2008打開(kāi)my_myqsl.dsp,編輯項(xiàng)目屬性。
     2.1 切換為Release版本,默認(rèn)是DEBUG版本
     2.2 右鍵項(xiàng)目屬性-》通配屬性-》C/C++-》預(yù)處理器-》預(yù)處理器定義除去其中的ZTS=1,因?yàn)槲覀儗⒕幾g為NTS版本。(非線程安全)
     2.3 右鍵項(xiàng)目屬性-》通配屬性-》C/C++-》常規(guī)-》附加包含目錄,新增MYSQL_ROOT/include。引入頭文件搜索路徑。
          這樣當(dāng)使用#include "mysql.h"時(shí),就不會(huì)出現(xiàn)搜索不到頭文件的錯(cuò)誤
     2.4 右鍵項(xiàng)目屬性-》通配屬性-》鏈接器-》常規(guī)-》附加庫(kù)目錄,新增MYSQL_ROOT/lib/opt,編譯擴(kuò)展時(shí)需要鏈接的DLL都在其中。(另外不要忘記引入php5nts.lib的路徑,這是任一擴(kuò)展編譯時(shí)都需要引入的)
     2.5 右鍵項(xiàng)目屬性-》通配屬性-》鏈接器-》輸入-》附加依賴項(xiàng)新增libmySQL.lib,意在編譯時(shí)設(shè)定需要鏈接的DLL。
3.新建my_mysql新的PHP資源類型。
4.實(shí)現(xiàn)PHP API,供給PHP接口使用。
5.編譯擴(kuò)展,拷貝生成的php_my_mysql.dll到PHP_ROOT/ext下,并修改php.ini,增加extension=ext/php_my_mysql.dll。
6.編寫PHP文件,調(diào)用擴(kuò)展中提供的函數(shù)并調(diào)試。

@MYSQL_ROOT:表示mysql的安裝路徑
@PHP_ROOT:表示php所在路徑

三、開(kāi)始編碼
ext/my_mysql/php_my_mysql.h

復(fù)制代碼 代碼如下:

/*
  +----------------------------------------------------------------------+
  | 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          |
  | [email protected] 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 */


接口測(cè)試test.php
復(fù)制代碼 代碼如下:

<?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;


測(cè)試結(jié)果:

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 成人毛片免费视频 | 91精品福利视频 | 日本最新免费二区三区 | 56av国产精品久久久久久久 | 国产成年人在线观看 | 国人精品视频在线观看 | av成人在线电影 | 久久资源总站 | 最近日本电影hd免费观看 | 欧美 中文字幕 | 欧美另类综合 | 国产88久久久国产精品免费二区 | 7777网站| 99精品视频99| 暴力肉体进入hdxxxx0 | 欧美一级电影网站 | 日本精品黄色 | 欧美高清第一页 | 欧美性色生活片免费播放 | 久久成人在线观看 | 最新中文字幕在线 | 久草在线高清视频 | 未成年人在线观看 | 国产精品99精品 | 毛片在线播放视频 | 在线成人一区二区 | 一级免费黄色免费片 | 黄色网址你懂的 | 欧美一级片网站 | 亚洲成a人在线 | 欧美性生交xxxxx久久久缅北 | 久久久久久三区 | 免费啪视频在线观看 | 国产精品成人久久 | 中文字幕网址 | 禁漫天堂久久久久久久久久 | 国内精品久久久久久久久久久久 | 精品国产一区二区三区四区在线 | 欧美性受ⅹ╳╳╳黑人a性爽 | 国产中出视频 | 亚洲一区二区中文字幕在线观看 |