欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

關于嘗試開發(fā)PHP的MYSQL擴展的使用

 更新時間:2013年04月17日 16:29:32   作者:  
本篇文章小編將為大家介紹,關于嘗試開發(fā)PHP的MYSQL擴展的使用,需要的朋友可以參考一下

一、前期準備
開發(fā)MYSQL擴展,當然得先安裝MYSQL
下載mysql-essential-5.1.65-win32

必須選上紅色的選項,因為開發(fā)MYSQL擴展時,需要頭文件和mysql的動態(tài)庫。否則擴展無法編譯成功。

這個擴展的目的主要是熟悉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);//執(zhí)行sql,可以是SELECT或INSERT、UPDATE、DELETE等有返回值與無返回值的查詢語句
PHP_FUNCTION(my_mysql_fetch_assoc);//獲取返回結果集
PHP_FUNCTION(my_mysql_get_insert_id);//獲取上一次執(zhí)行INSERT的自增ID

二、開發(fā)思路
1.通過ext_skel_win32.php(骨架工具)創(chuàng)建my_mysql擴展。
2.使用VS2008打開my_myqsl.dsp,編輯項目屬性。
     2.1 切換為Release版本,默認是DEBUG版本
     2.2 右鍵項目屬性-》通配屬性-》C/C++-》預處理器-》預處理器定義除去其中的ZTS=1,因為我們將編譯為NTS版本。(非線程安全)
     2.3 右鍵項目屬性-》通配屬性-》C/C++-》常規(guī)-》附加包含目錄,新增MYSQL_ROOT\include。引入頭文件搜索路徑。
          這樣當使用#include "mysql.h"時,就不會出現搜索不到頭文件的錯誤
     2.4 右鍵項目屬性-》通配屬性-》鏈接器-》常規(guī)-》附加庫目錄,新增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;


測試結果:

相關文章

  • C++控制臺實現密碼管理系統

    C++控制臺實現密碼管理系統

    這篇文章主要為大家詳細介紹了C++控制臺實現密碼管理系統,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • C語言標準庫<math.h>和<setjmp.h>的實現

    C語言標準庫<math.h>和<setjmp.h>的實現

    本文主要介紹了C語言標準庫<math.h>和<setjmp.h>的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-11-11
  • 用C語言實現掃雷小游戲

    用C語言實現掃雷小游戲

    這篇文章主要為大家詳細介紹了用C語言實現掃雷小游戲,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-06-06
  • C/C++實現線性單鏈表的示例代碼

    C/C++實現線性單鏈表的示例代碼

    使用鏈存儲結構的線性存儲結構為線性單鏈表,本文將分別利用C語言和C++實現線性單鏈表,感興趣的小伙伴可以跟隨小編一起學習一下
    2022-05-05
  • C++實現LeetCode(191.位1的個數)

    C++實現LeetCode(191.位1的個數)

    這篇文章主要介紹了C++實現LeetCode(191.位1的個數),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內容,需要的朋友可以參考下
    2021-08-08
  • C++中“#”號的使用技巧

    C++中“#”號的使用技巧

    本篇文章是對C++中“#”號的使用技巧進行了分析介紹,需要的朋友參考下
    2013-05-05
  • 深入了解C++11中promise和future的使用

    深入了解C++11中promise和future的使用

    C++11中promise和future機制是用于并發(fā)編程的一種解決方案,用于在不同線程完成數據傳遞(異步操作)。Promise和Future提供了訪問異步操作結果的機制,可以在線程之間傳遞數據和異常消息。本文就來聊聊二者的使用,希望對大家有所幫助
    2022-11-11
  • C語言開發(fā)實現井字棋及電腦落子優(yōu)化示例詳解

    C語言開發(fā)實現井字棋及電腦落子優(yōu)化示例詳解

    以前上課經常和同桌玩起井字棋,那么我們就當我們回憶童年,現在也用C語言來實現井字棋,本次代碼相對于初階的井字棋,在電腦下棋代碼部分做了優(yōu)化,使得電腦更加具有威脅
    2021-11-11
  • VS Code如何編寫C/C++程序的實現步驟

    VS Code如何編寫C/C++程序的實現步驟

    本文主要介紹了VS Code如何編寫C/C++程序的實現步驟,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • C語言實現斗地主的核心算法

    C語言實現斗地主的核心算法

    本文給大家分享的是使用C語言實現的斗地主游戲的核心算法,主要實現了面向對象設計,洗牌、發(fā)牌、判斷牌型、比較牌的大小、游戲規(guī)則等算法。通過這個斗地主小項目的練習,提高了我的面向對象設計能力,加深了對算法的理解。最近把這些設計和算法分享給大家。
    2015-03-03

最新評論