PHP連接MySQL數(shù)據(jù)庫三種實現(xiàn)方法
引言
PHP與MySQL的連接有三種API接口,分別是:PHP的MySQL擴展 、PHP的mysqli擴展 、PHP數(shù)據(jù)對象(PDO) ,下面針對以上三種連接方式做下總結(jié),以備在不同場景下選出最優(yōu)方案。
PHP的MySQL擴展是設(shè)計開發(fā)允許php應用與MySQL數(shù)據(jù)庫交互的早期擴展。MySQL擴展提供了一個面向過程的接口,并且是針對MySQL4.1.3或者更早版本設(shè)計的。因此這個擴展雖然可以與MySQL4.1.3或更新的數(shù)據(jù)庫服務端進行交互,但并不支持后期MySQL服務端提供的一些特性。由于太古老,又不安全,所以已被后來的mysqli完全取代;
PHP的mysqli擴展,我們有時稱之為MySQL增強擴展,可以用于使用 MySQL4.1.3或更新版本中新的高級特性。其特點為:面向?qū)ο蠼涌?、prepared語句支持、多語句執(zhí)行支持、事務支持 、增強的調(diào)試能力、嵌入式服務支持 、預處理方式完全解決了sql注入的問題。不過其也有缺點,就是只支持mysql數(shù)據(jù)庫。如果你要是不操作其他的數(shù)據(jù)庫,這無疑是最好的選擇。
PDO是PHP Data Objects的縮寫,是PHP應用中的一個數(shù)據(jù)庫抽象層規(guī)范。PDO提供了一個統(tǒng)一的API接口可以使得你的PHP應用不去關(guān)心具體要連接的數(shù)據(jù)庫服務器系統(tǒng)類型,也就是說,如果你使用PDO的API,可以在任何需要的時候無縫切換數(shù)據(jù)庫服務器,比如從Oracle 到MySQL,僅僅需要修改很少的PHP代碼。其功能類似于JDBC、ODBC、DBI之類接口。同樣,其也解決了sql注入問題,有很好的安全性。不過他也有缺點,某些多語句執(zhí)行查詢不支持(不過該情況很少)。
代碼示例
PHP與Mysql擴展(本擴展自 PHP 5.5.0 起已廢棄,并在將來會被移除),PHP原生的方式去連接數(shù)據(jù)庫,是面向過程的
$mysql_conf = array( 'host' => '127.0.0.1:3306', 'db' => 'test', 'db_user' => 'root', 'db_pwd' => 'root', ); $mysql_conn = @mysql_connect($mysql_conf['host'], $mysql_conf['db_user'], $mysql_conf['db_pwd']); if (!$mysql_conn) { die("could not connect to the database:\n" . mysql_error());//診斷連接錯誤 } mysql_query("set names 'utf8'");//編碼轉(zhuǎn)化 $select_db = mysql_select_db($mysql_conf['db']); if (!$select_db) { die("could not connect to the db:\n" . mysql_error()); } $sql = "select * from user;"; $res = mysql_query($sql); if (!$res) { die("could get the res:\n" . mysql_error()); } while ($row = mysql_fetch_assoc($res)) { print_r($row); } mysql_close($mysql_conn);
PHP與Mysqli擴展,面向過程、對象
<?php $mysql_conf = array( 'host' => '127.0.0.1:3306', 'db' => 'test', 'db_user' => 'root', 'db_pwd' => 'joshua317', ); $mysqli = @new mysqli($mysql_conf['host'], $mysql_conf['db_user'], $mysql_conf['db_pwd']); if ($mysqli->connect_errno) { die("could not connect to the database:\n" . $mysqli->connect_error);//診斷連接錯誤 } $mysqli->query("set names 'utf8';");//編碼轉(zhuǎn)化 $select_db = $mysqli->select_db($mysql_conf['db']); if (!$select_db) { die("could not connect to the db:\n" . $mysqli->error); }$sql = "select uid from user where name = 'joshua';"; $res = $mysqli->query($sql); if (!$res) { die("sql error:\n" . $mysqli->error); } while ($row = $res->fetch_assoc()) { var_dump($row); } $res->free(); $mysqli->close(); ?>
PHP與PDO擴展,面向過程、對象
<?php $mysql_conf = array( 'host' => '127.0.0.1:3306', 'db' => 'test', 'db_user' => 'root', 'db_pwd' => 'joshua317', ); try { $pdo = new PDO("mysql:host=" . $mysql_conf['host'] . ";dbname=" . $mysql_conf['db'], $mysql_conf['db_user'], $mysql_conf['db_pwd']);//創(chuàng)建一個pdo對象 $pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION); // 設(shè)置sql語句查詢?nèi)绻霈F(xiàn)問題 就會拋出異常 //set_exception_handler("cus_exception_handler"); } catch (PDOException $e) { die("connect error:".$e->getMessage()); } $pdo->exec("set names 'utf8'"); $sql = "select * from user where name = ?"; $stmt = $pdo->prepare($sql); $stmt->bindValue(1, 'joshua', PDO::PARAM_STR); $rs = $stmt->execute(); if ($rs) { // PDO::FETCH_ASSOC 關(guān)聯(lián)數(shù)組形式 // PDO::FETCH_NUM 數(shù)字索引數(shù)組形式 while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) { var_dump($row); } }
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
- 一文詳解PHP連接MySQL數(shù)據(jù)庫的三種方式
- PHP連接MySQL數(shù)據(jù)庫操作代碼實例解析
- PHP連接MySQL數(shù)據(jù)庫的三種方式實例分析【mysql、mysqli、pdo】
- php連接mysql數(shù)據(jù)庫最簡單的實現(xiàn)方法
- PHP連接MySQL數(shù)據(jù)庫并以json格式輸出
- PHP基于MySQLI函數(shù)封裝的數(shù)據(jù)庫連接工具類【定義與用法】
- php連接mysql數(shù)據(jù)庫
- PHP連接MYSQL數(shù)據(jù)庫的3種常用方法
- PHP連接MySql數(shù)據(jù)庫方法簡化版
相關(guān)文章
ThinkPHP讓../Public在模板不解析(直接輸出)的方法
這篇文章主要介紹了ThinkPHP讓../Public在模板不解析,直接輸出的方法,涉及通過模板常量設(shè)置修改默認變量替換的技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-10-10php計算幾分鐘前、幾小時前、幾天前的幾個函數(shù)、類分享
這篇文章主要介紹了php計算時間幾分鐘前、幾小時前、幾天前的幾個函數(shù)、類分享,需要的朋友可以參考下2014-04-04Laravel Validator自定義錯誤返回提示消息并在前端展示
這篇文章主要給大家介紹了關(guān)于Laravel Validator自定義錯誤返回提示消息并在前端展示的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Laravel具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧2019-05-05php實現(xiàn)HTML實體編號與非ASCII字符串相互轉(zhuǎn)換類實例
本篇文章主要介紹了"php實現(xiàn)HTML實體編號與非ASCII字符串相互轉(zhuǎn)換類實例",主要涉及到HTML實體編號與非ASCII字符串相互轉(zhuǎn)換類方面的內(nèi)容,感興趣的同學可以參考一下。2016-11-11將PHP的session數(shù)據(jù)存儲到數(shù)據(jù)庫中的代碼實例
這里我們將分享兩個將PHP的session數(shù)據(jù)存儲到數(shù)據(jù)庫中的代碼實例,分別針對PostgreSQL與MySQL,需要的朋友可以參考下2016-06-06yii2.0框架實現(xiàn)上傳excel文件后導入到數(shù)據(jù)庫的方法示例
這篇文章主要介紹了yii2.0框架實現(xiàn)上傳excel文件后導入到數(shù)據(jù)庫的方法,結(jié)合實例形式詳細分析了yii2.0上傳excel文件后導入到數(shù)據(jù)庫的相關(guān)模型、視圖、控制器實現(xiàn)技巧,需要的朋友可以參考下2020-04-04