亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C > 正文

關于嘗試開發PHP的MYSQL擴展的使用

2020-01-26 16:19:21
字體:
來源:轉載
供稿:網友

一、前期準備
開發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;


測試結果:

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品2019中文字幕| 日韩国产欧美区| 久久精品免费播放| 另类专区欧美制服同性| 亚洲精品国偷自产在线99热| 亚洲肉体裸体xxxx137| 亚洲伊人成综合成人网| 日韩av网站大全| 亚洲成人精品久久久| 国产一区二区三区在线免费观看| 日韩电影视频免费| 国外成人性视频| 精品无人区太爽高潮在线播放| 一区二区三区回区在观看免费视频| 国产精品情侣自拍| 国产日产欧美精品| 国产精品91久久| 欧美激情综合色| 亚洲一区二区少妇| 91av在线看| 亚洲性视频网址| 国产成人小视频在线观看| 性欧美长视频免费观看不卡| 精品欧美激情精品一区| 91精品国产网站| 日韩精品中文字幕在线播放| 国产成人av在线| 亚洲一区www| 国产一区二区三区三区在线观看| 国产精品成久久久久三级| 色综合亚洲精品激情狠狠| 精品二区三区线观看| 国产精品久久网| 久久久精品视频成人| 亚洲视频一区二区三区| 91精品国产91久久久久久最新| 亚洲国产欧美在线成人app| 最好看的2019年中文视频| 亚洲人成毛片在线播放| 欧美精品一本久久男人的天堂| www.日韩av.com| 亚洲一区999| 欧美激情精品久久久久久| 欧美电影免费观看高清完整| 一区二区欧美激情| 深夜福利一区二区| 国产精品日韩在线| 欧美巨乳美女视频| 欧美视频在线免费| 中文字幕亚洲情99在线| 国产欧美一区二区三区久久人妖| 国产97在线观看| 最新国产成人av网站网址麻豆| 日韩成人中文字幕| 国产精品高潮呻吟久久av黑人| 亚洲天堂男人天堂| 国产精品一区二区三区免费视频| 欧美精品在线网站| 亚洲综合在线中文字幕| 一区二区三区视频在线| 亚洲人成在线播放| 国产精品入口福利| 色视频www在线播放国产成人| 国产精品自拍偷拍| 亚洲成人av片| 亚洲欧美中文日韩v在线观看| 高清欧美性猛交xxxx黑人猛交| 欧美老少配视频| 欧美亚洲激情在线| 国产亚洲精品久久久| 日韩视频精品在线| 韩剧1988免费观看全集| 久久久精品国产网站| 亚洲激情视频在线观看| 91黑丝高跟在线| 高清视频欧美一级| 欧美专区国产专区| 欧美高清不卡在线| 国产mv免费观看入口亚洲| 欧美网站在线观看| 日韩欧美在线免费观看| 成人欧美在线观看| 97超级碰在线看视频免费在线看| 欧美大成色www永久网站婷| 久久久国产在线视频| 成人在线播放av| 亚洲电影成人av99爱色| 久久综合网hezyo| 久久99国产综合精品女同| 亚洲淫片在线视频| 51精品国产黑色丝袜高跟鞋| 欧美中文字幕在线播放| 免费91麻豆精品国产自产在线观看| 国产欧美中文字幕| 亚洲激情视频在线播放| 欧美日韩成人免费| 亚洲护士老师的毛茸茸最新章节| 欧美性受xxxx黑人猛交| 亚洲图片欧美午夜| 美女扒开尿口让男人操亚洲视频网站| 午夜精品久久久久久久男人的天堂| 欧美xxxwww| 亚洲高清一区二| 中文字幕亚洲激情| 亚洲午夜久久久影院| 日本不卡免费高清视频| 91成品人片a无限观看| 欧美国产视频一区二区| 日韩视频在线免费观看| 国产精品欧美在线| 欧美美最猛性xxxxxx| 欧美激情亚洲一区| 北条麻妃在线一区二区| 一区二区中文字幕| 国产精品久久视频| 97热在线精品视频在线观看| 亚洲一区二区在线播放| 91精品国产综合久久香蕉的用户体验| 欧美国产视频一区二区| 国产精品1区2区在线观看| 国产亚洲精品久久久| 亚洲va欧美va国产综合剧情| 国产精品1区2区在线观看| 国产91精品在线播放| 国产精品流白浆视频| 国产精品777| www.久久久久久.com| 国产视频亚洲视频| 2019中文字幕在线免费观看| 欧美另类高清videos| 久久中文字幕在线| 国产美女精品视频| 中文字幕亚洲字幕| 国产91成人video| 中文字幕亚洲天堂| 亚洲精品中文字幕女同| 亚洲2020天天堂在线观看| 日韩精品免费在线播放| 日韩一区二区在线视频| 亚洲综合av影视| 亚洲伦理中文字幕| 高清视频欧美一级| 精品久久久久久久久久| 免费91麻豆精品国产自产在线观看| 久久久久久久影视| 最近2019年日本中文免费字幕| 亚洲福利精品在线| 国产精品一二三视频| 国产欧美日韩最新| 91在线高清视频| 欧美专区在线观看| 日韩中文字幕网址| 91高清免费在线观看| 欧美日韩精品在线| 欧美丰满老妇厨房牲生活| 久久艹在线视频| 中文字幕少妇一区二区三区| 欧美日韩国产精品一区二区三区四区| 亚洲免费小视频| 亚洲性av网站| 精品动漫一区二区| 亚洲激情视频在线播放| 国产精品久久久久av| 97香蕉超级碰碰久久免费的优势|