站長資訊網
        最全最豐富的資訊網站

        php連接數據庫的方式有哪些?

        PHP與MySQL的連接有三種API接口,分別是:PHP的MySQL擴展 、PHP的mysqli擴展 、PHP數據對象(PDO) ,下面針對以上三種連接方式做下總結,以備在不同場景下選出最優方案。

        php連接數據庫的方式有哪些?

        PHP的MySQL擴展是設計開發允許php應用與MySQL數據庫交互的早期擴展。MySQL擴展提供了一個面向過程的接口,并且是針對MySQL4.1.3或者更早版本設計的。因此這個擴展雖然可以與MySQL4.1.3或更新的數據庫服務端進行交互,但并不支持后期MySQL服務端提供的一些特性。由于太古老,又不安全,所以已被后來的mysqli完全取代;

        PHP的mysqli擴展,我們有時稱之為MySQL增強擴展,可以用于使用 MySQL4.1.3或更新版本中新的高級特性。其特點為:面向對象接口 、prepared語句支持、多語句執行支持、事務支持 、增強的調試能力、嵌入式服務支持 、預處理方式完全解決了sql注入的問題。不過其也有缺點,就是只支持mysql數據庫。如果你要是不操作其他的數據庫,這無疑是最好的選擇。

        PDO是PHP Data Objects的縮寫,是PHP應用中的一個數據庫抽象層規范。PDO提供了一個統一的API接口可以使得你的PHP應用不去關心具體要連接的數據庫服務器系統類型,也就是說,如果你使用PDO的API,可以在任何需要的時候無縫切換數據庫服務器,比如從Oracle 到MySQL,僅僅需要修改很少的PHP代碼。其功能類似于JDBC、ODBC、DBI之類接口。同樣,其也解決了sql注入問題,有很好的安全性。不過他也有缺點,某些多語句執行查詢不支持(不過該情況很少)。

        官文對于三者之間也做了列表性的比較:

        PHP的mysqli擴展 PDO PHP的mysql擴展
        引入的PHP版本 5.0 5.0 3.0之前
        PHP5.x是否包含 是  
        MySQL開發狀態 活躍 在PHP5.3中活躍 僅維護
        在MySQL新項目中的建議使用程度 建議 – 首選 建議 不建議
        API的字符集支持
        服務端prepare語句的支持情況
        客戶端prepare語句的支持情況
        存儲過程支持情況
        多語句執行支持情況 大多數
        是否支持所有MySQL4.1以上功能 大多數

        從官方給出的這份結果上來看,優先推薦msqli,其次是PDO 。而“民間”給出的結果很多是傾向于使用PDO,因為其不擔有跨庫的優點,更有讀寫速度快的特點。

        1、PHP與Mysql擴展(本擴展自 PHP 5.5.0 起已廢棄,并在將來會被移除),PHP原生的方式去連接數據庫,是面向過程的

        <?php $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'");//編碼轉化 $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); ?>

        2、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';");//編碼轉化 $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(); ?>

        3、PHP與PDO擴展,面向過程、對象

        <?php $mysql_conf = array(     'host'    => '127.0.0.1:3306',      'db'      => 'test',      'db_user' => 'root',      'db_pwd'  => 'joshua317',      ); $pdo = new PDO("mysql:host=" . $mysql_conf['host'] . ";dbname=" . $mysql_conf['db'], $mysql_conf['db_user'], $mysql_conf['db_pwd']);//創建一個pdo對象 $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 關聯數組形式     // PDO::FETCH_NUM 數字索引數組形式     while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {         var_dump($row);     } }  $pdo = null;//關閉連接 ?>

        贊(0)
        分享到: 更多 (0)
        網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
        主站蜘蛛池模板: A级精品国产片在线观看| 2022免费国产精品福利在线| 久久久精品人妻一区二区三区四| 91亚洲国产成人久久精品网址| 无码日韩精品一区二区免费| 九九久久精品无码专区| 亚洲精品视频在线| avtt天堂网久久精品| 中文字幕日韩精品有码视频| 久久www免费人成精品香蕉| 在线电影国产精品| 国产福利91精品一区二区三区| 精品熟女少妇a∨免费久久| 最新精品露脸国产在线 | 久久精品国产亚洲AV无码偷窥| 欧美激情视频精品一区二区| 国产精品va在线观看无码| 亚洲色图国产精品| 欧美精品高清在线观看| 国产精品莉莉欧美自在线线 | 最新国产精品无码| 久久夜色撩人精品国产小说| 国产精品无打码在线播放| 先锋影音国产精品| 亚洲国产精品免费视频| 欧美精品福利视频| 青青草国产精品久久久久| 欧美精品在线一区二区三区| 久久96国产精品久久久| 精品国产自在在线在线观看| 99香蕉国产精品偷在线观看| 91久久精品91久久性色| 国产精品久久久久久福利漫画 | 99精品国产一区二区三区2021| 国产精品多人p群无码| 人妻少妇精品视频二区 | 熟女精品视频一区二区三区| 无码精品国产一区二区三区免费| 四虎成人精品无码| 孩交VIDEOS精品乱子| 99久久国产综合精品麻豆|