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

首頁 > 編程 > PHP > 正文

PHP數據庫抽象層PDO(PHP Data Object)[一]

2020-03-22 17:41:50
字體:
來源:轉載
供稿:網友
  • 1、簡介:(PDO數據庫訪問抽象層,統一各種 數據庫的訪問接口)

    PHP 數據對象 (PDO) 擴展為PHP訪問數據庫定義了一個輕量級的一致接口。實現 PDO 接口的每個數據庫驅動可以公開具體數據庫的特性作為標準擴展功能。 注意利用 PDO 擴展自身并不能實現任何數據庫功能;必須使用一個 具體數據庫的 PDO 驅動 來訪問數據庫服務。 PDO 提供了一個 數據訪問 抽象層,這意味著,不管使用哪種數據庫,都可以用相同的函數(方法)來查詢和獲取數據。 PDO 不不提供 數據庫 抽象層;它不會重寫 SQL,也不會模擬缺失的特性。如果需要的話,應該使用一個成熟的抽象層。 (http://php.net/manual/zh/intro.pdo.php) 2、特點 3、開啟PDO 在 php.ini 中的 php_pdo.dll后面啟用。例如:
    1. extension=php_pdo_mysql.dll
    2. extension=php_pdo_pgsql.dll DLL 文件應該在系統的extension_dir 中存在。更改 php.ini 文件后需要重啟 PHP 服務才能使新的配置指令生效。 4、PDO連接數據庫 更加詳細的信息:http://php.net/manual/zh/pdo.construct.php 4.1、通過參數形式
      1. 1<?php
      2. 2// 通過參數形式連接數據庫
      3. 3try{
      4. 4 $dsn ='mysql:host=localhost;dbname=pdotest';
      5. 5 $name ='root';
      6. 6 $passwd ='root';
      7. 7 $pdo =new PDO($dsn, $name, $passwd);
      8. 8 var_dump($pdo);
      9. 9}catch(PDOException $e){
      10. 10 echo $e->getMessage();
      11. 11}
      12. 12 4.2、通過URI形式 創建pdo_uri_conn.txt文件
        1. mysql:dbname=pdotest;host=localhost; Uri連接數據庫
          1. <?php
          2. // 通過參數形式連接數據庫
          3. try{
          4. $dsn ='uri:/var/www/html/php-code/pdo/pdo_uri_conn.txt';
          5. $name ='root';
          6. $passwd ='root';
          7. $pdo =new PDO($dsn, $name, $passwd);
          8. var_dump($pdo);
          9. }catch(PDOException $e){
          10. echo $e->getMessage();
          11. } 4.3、通過配置php.ini文件的形式連接數據庫 在你的php.ini文件的加入這一句; 注意重啟Apache服務器 鏈接數據庫 注意: 連接數據成功后,返回一個 PDO 類的實例給腳本,此連接在 PDO 對象的生存周期中保持活動。要想關閉連接,需要銷毀對象以確保所有剩余到它的引用都被刪除,可以賦一個 NULL 值給對象變量。如果不明確地這么做,PHP 在腳本結束時會自動關閉連接。
            1. <?php
            2. ......
            3. // 現在運行完成,在此關閉連接
            4. $dbh =null; 5、PDO對象使用 5.1、exec()方法 exec()方法執行一條sql語句,返回受修改或刪除 SQL 語句影響的行數。如果沒有受影響的行,則 PDO::exec() 返回 0 注意:PDO::exec() 不會從一條 SELECT 語句中返回結果。對于在程序中只需要發出一次的 SELECT 語句,可以考慮使用 PDO::query()。 5.1.1、 使用 exec() 方法完成建表
              1. 1<?php
              2. 2// 通過參數形式連接數據庫
              3. 3try{
              4. 4 $dsn ='mysql:host=localhost;dbname=pdotest';
              5. 5 $name ='root';
              6. 6 $passwd ='root';
              7. 7 $pdo =new PDO($dsn, $name, $passwd);
              8. 8 $sql =<<<EOF
              9. 9 CREATE TABLE IF NOT EXISTS user(
              10. 10 id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
              11. 11 name VARCHAR(20) NOT NULL UNIQUE,
              12. 12 passwd VARCHAR(32) NOT NULL,
              13. 13 email VARCHAR(30) NOT NULL
              14. 14);
              15. 15 EOF;
              16. 16// exec 對于沒有受影響的行數將返回0
              17. 17 $res = $pdo->exec($sql);
              18. 18 var_dump($res);
              19. 19// 現在運行完成,在此關閉連接
              20. 20 $pdo =null;
              21. 21}catch(PDOException $e){
              22. 22 echo $e->getMessage();
              23. 23}
              24. 24
              25. 25 5.1.2、使用exec() 插入數據
                1. 1<?php
                2. 2// 通過參數形式連接數據庫
                3. 3try{
                4. 4 $dsn ='mysql:host=localhost;dbname=pdotest';
                5. 5 $name ='root';
                6. 6 $passwd ='root';
                7. 7 $pdo =new PDO($dsn, $name, $passwd);
                8. 8 $sql ='
                9. 9 INSERT INTO user (name, passwd, email)
                10. 10 VALUES('wangxb', MD5('123'), 'wangxb@mail.com'),
                11. 11 ('wangxb1', MD5('123'), 'wangxb@mail.com'),
                12. 12 ('wangxb2', MD5('123'), 'wangxb@mail.com')
                13. 13 ';
                14. 14// exec 對于沒有受影響的行數將返回0
                15. 15 $res = $pdo->exec($sql);
                16. 16 var_dump($res);
                17. 17// 返回最后插入行的ID或序列值
                18. 18 echo $pdo->lastInsertId();
                19. 19// 現在運行完成,在此關閉連接
                20. 20 $pdo =null;
                21. 21}catch(PDOException $e){
                22. 22 echo $e->getMessage();
                23. 23}
                24. 24 返回: 5.1.3、exec()執行更新和刪除與插入類似,這里不再贅述。 5.1.4、exec()方法對select是沒有作用的,因為沒有受影響的行數,雖然這么做沒有什么程序語法上的錯誤,但是執行select時將返回 int(0),取不出我們想要的任何東西,所以exec不適合執行select語句。 5.2、errorCode()和errorInfo()方法返回錯誤信息 PDO::errorCode — 獲取跟數據庫句柄上一次操作相關的 SQLSTATE PDO::errorInfo — 返回錯誤信息的一個數組
                  0: SQLSTATE error code
                  1: specific error code.
                  2: specific error message
                  1. 1<?php
                  2. 2/*
                  3. 3 * 使用errorCode 和 errorInfo 兩個方法顯示錯誤信息
                  4. 1 <?php
                  5. 2 /*
                  6. 3 * 使用errorCode 和 errorInfo 兩個方法顯示錯誤信息
                  7. 4 */
                  8. 5try{
                  9. 6 $dsn ='mysql:host=localhost;dbname=pdotest';
                  10. 7 $name ='root';
                  11. 8 $passwd ='root';
                  12. 9 $pdo =new PDO($dsn, $name, $passwd);
                  13. 10// 我們這里插入的一個沒有的表 user123 中
                  14. 11 $sql ='
                  15. 12 INSERT INTO user123 (name, passwd, email)
                  16. 13 VALUES('wangxb', MD5('123'), 'wangxb@mail.com')
                  17. 14 ';
                  18. 15//
                  19. 16 $res = $pdo->exec($sql);
                  20. 17if(false=== $res){
                  21. 18// errorCode 獲取跟數據庫句柄上一次操作相關的 SQLSTATE
                  22. 19 echo $pdo->errorCode();
                  23. 20print' ';
                  24. 21// errorInfo 返回一個錯誤信息數據:
                  25. 22// 0: SQLSTATE error code
                  26. 23// 1: specific error code.
                  27. 24// 2: specific error message
                  28. 25 print_r($pdo->errorInfo());
                  29. 26returnfalse;
                  30. 27}
                  31. 28 var_dump($res);
                  32. 29// 返回最后插入行的ID或序列值
                  33. 30 echo '最后一天插入的信息ID:'.$pdo->lastInsertId();
                  34. 31// 現在運行完成,在此關閉連接
                  35. 32 $pdo =null;
                  36. 33}catch(PDOException $e){
                  37. 34 echo $e->getMessage();
                  38. 35}
                  39. 36 運行:
                  我們在mysql客戶端執行相同語句
                  可以看到 errorInfo()返回的信息其實是將mysql錯誤信息以數組的形式返回
                  5.3、query()方法執行查詢 query()方法雖然可以執行任何sql語句,但是更多的時候是執行select,對于insert、update、delete等使用exec()方法
                  1. 1<?php
                  2. 2/*
                  3. 3 * 使用exec方法執行插入語句
                  4. 4 */
                  5. 5// 通過參數形式連接數據庫
                  6. 6try{
                  7. 7 $dsn ='mysql:host=localhost;dbname=pdotest';
                  8. 8 $name ='root';
                  9. 9 $passwd ='root';
                  10. 10 $pdo =new PDO($dsn, $name, $passwd);
                  11. 11//$sql = 'SELECT * FROM user WHERE id=12';
                  12. 12 $sql ='SELECT * FROM user';
                  13. 13// query 方法執行將返回一個PDOStatment對象
                  14. 14 $stmt = $pdo->query($sql);
                  15. 15if(!$pdo &&!$stmt){
                  16. 16 var_dump($pdo->errorInof());
                  17. 17}
                  18. 18// 對于query返回的PDOStatment對象,我們同樣可是使用foreach方法來遍歷數據其中的數據
                  19. 19foreach($stmt as $row){
                  20. 20 var_dump($row);
                  21. 21 echo '<hr>';
                  22. 22}
                  23. 23
                  24. 24// 這里注意:雖然手冊上說query返回的是一個PDOStatment對象,但是下面這里使用PDOStatment對象方法時反悔了false,有待以后學習理解
                  25. 25 echo '-------------------<br>';
                  26. 26 var_dump($stmt->fetch());
                  27. 27 echo '-------------------<br>';
                  28. 28
                  29. 29// prepare方法是為execute準備一個statmentObj
                  30. 30 $sth = $pdo -> prepare ('SELECT name, id FROM user');
                  31. 31 $sth -> execute ();
                  32. 32 echo '++++++++++++++++++++++++';
                  33. 33 var_dump($sth->fetch());
                  34. 34 echo '++++++++++++++++++++++++';
                  35. 35 var_dump($stmt);
                  36. 36// 現在運行完成,在此關閉連接
                  37. 37 $pdo =null;
                  38. 38}catch(PDOException $e){
                  39. 39 echo $e->getMessage();
                  40. 40}
                  41. 41
                  42. 42
                  43. 43 5.4、prepare()和execute()方法
                    1. 1<?php
                    2. 2/*
                    3. 3 * 使用exec方法執行插入語句
                    4. 4 */
                    5. 5// 通過參數形式連接數據庫
                    6. 6try{
                    7. 7 $dsn ='mysql:host=localhost;dbname=pdotest';
                    8. 8 $name ='root';
                    9. 9 $passwd ='root';
                    10. 10 $pdo =new PDO($dsn, $name, $passwd);
                    11. 11
                    12. 12/*
                    13. 13 * 使用prepare和execute方法形式
                    14. 14 */
                    15. 15 $id1 =12;
                    16. 16 $id2 =13;
                    17. 17// 利用占位符形式
                    18. 18 $sql ='SELECT * FROM user WHERE id=? OR id=?';
                    19. 19 $sth = $pdo -> prepare ($sql);
                    20. 20 $sth -> execute(array($id1, $id2));
                    21. 21 var_dump($sth->fetchAll(PDO::FETCH_ASSOC));
                    22. 22
                    23. 23 echo '<hr>';
                    24. 24// 使用參數形式
                    25. 25 $sql_1 ='SELECT id, name FROM user WHERE id= :id';
                    26. 26 $sth_1 = $pdo -> prepare ($sql_1);
                    27. 27 $sth_1 -> execute(array('id'=>$id1));
                    28. 28 var_dump($sth_1->fetchAll(PDO::FETCH_ASSOC));
                    29. 29
                    30. 30 echo '<hr>';
                    31. 31// 使用bindParam方式
                    32. 32 $sql_2 ='SELECT * FROM user WHERE id=? OR id=?';
                    33. 33 $sth_2 = $pdo -> prepare ($sql_2);
                    34. 34 $sth_2->bindParam(1, $id1, PDO::PARAM_INT);
                    35. 35 $sth_2->bindParam(2, $id2, PDO::PARAM_INT);
                    36. 36 $sth_2 -> execute();
                    37. 37 var_dump($sth_2->fetchAll(PDO::FETCH_ASSOC));
                    38. 38
                    39. 39// 現在運行完成,在此關閉連接
                    40. 40 $pdo =null;
                    41. 41}catch(PDOException $e){
                    42. 42 echo $e->getMessage();
                    43. 43}
                    44. 44 5.5、getAttribute ( int $attribute ) 和setAttribute ( int $attribute , mixed $value ) 方法
                      1. 1<?php
                      2. 2/*
                      3. 3 * 使用exec方法執行插入語句
                      4. 4 */
                      5. 5// 通過參數形式連接數據庫
                      6. 6try{
                      7. 7 $dsn ='mysql:host=localhost;dbname=pdotest';
                      8. 8 $name ='root';
                      9. 9 $passwd ='root';
                      10. 10 $pdo =new PDO($dsn, $name, $passwd);
                      11. 11 $sql ='SELECT * FROM user';
                      12. 12 echo '自動提交:'.$pdo->getAttribute(PDO::ATTR_AUTOCOMMIT);
                      13. 13 echo '<br/>';
                      14. 14 echo 'PDO默認的錯誤處理模式:'.$pdo->getAttribute(PDO::ATTR_ERRMODE);
                      15. 15
                      16. 16 echo '<br/>';
                      17. 17//現在我們重設自動提交
                      18. 18 $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);
                      19. 19 echo '重設后的自動提交:'.$pdo->getAttribute(PDO::ATTR_AUTOCOMMIT);
                      20. 20
                      21. 21// 現在運行完成,在此關閉連接
                      22. 22 $pdo =null;
                      23. 23
                      24. 24// 我們也可以在new一個PDO對象時,利用傳遞參數中的第四個參數(可省略)來設置我們此次連接數據庫時的各項參數
                      25. 25// (我們可以在這里找到所有的設置項:http://php.net/manual/zh/pdo.constants.php)
                      26. 26// 就像下面這樣
                      27. 27 $dsn ='mysql:host=localhost;dbname=pdotest';
                      28. 28 $name ='root';
                      29. 29 $passwd ='root';
                      30. 30 $option = array(
                      31. 31 PDO::ATTR_AUTOCOMMIT => O,
                      32. 32 PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION
                      33. 33);
                      34. 34 $pdo =new PDO($dsn, $name, $passwd, $option);
                      35. 35 echo '<hr/>';
                      36. 36 echo '使用option設置后';
                      37. 37 echo '<br/>';
                      38. 38 echo '自動提交:'.$pdo->getAttribute(PDO::ATTR_AUTOCOMMIT);
                      39. 39 echo '<br/>';
                      40. 40 echo 'PDO錯誤處理模式:'.$pdo->getAttribute(PDO::ATTR_ERRMODE);
                      41. 41}catch(PDOException $e){
                      42. 42 echo $e->getMessage();
                      43. 43}
                      44. 44


    PHP編程

    鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

  • 發表評論 共有條評論
    用戶名: 密碼:
    驗證碼: 匿名發表
    亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
    91免费看片网站| 欧美插天视频在线播放| 欧美精品18videos性欧美| 色噜噜久久综合伊人一本| 国产999在线观看| 日韩在线视频免费观看| 欧美在线免费视频| 欧美麻豆久久久久久中文| 国产一级揄自揄精品视频| 亚洲精品乱码久久久久久金桔影视| 国产网站欧美日韩免费精品在线观看| 欧美裸体xxxx| 大荫蒂欧美视频另类xxxx| 国产精品av免费在线观看| 91精品久久久久久久久久久久久久| 欧美在线视频网站| 在线观看久久av| 欧美日韩性生活视频| 日韩视频―中文字幕| 亚洲影院色无极综合| 国产亚洲欧美日韩一区二区| 亚洲欧美日韩成人| 国产精品久久久久久久久久小说| 日韩有码片在线观看| 8x拔播拔播x8国产精品| 7777精品久久久久久| 亚洲r级在线观看| 日韩欧美中文字幕在线观看| 欧美高跟鞋交xxxxxhd| 日韩最新免费不卡| 91国产视频在线播放| 亚洲人成电影网站色…| 亚洲欧美日韩精品久久奇米色影视| 亚洲欧洲日韩国产| 北条麻妃在线一区二区| 91久久国产综合久久91精品网站| 亚洲娇小xxxx欧美娇小| 77777亚洲午夜久久多人| 亚洲区一区二区| 美女扒开尿口让男人操亚洲视频网站| 亚洲乱亚洲乱妇无码| 日韩精品免费在线视频观看| 亚洲精品电影网| 麻豆一区二区在线观看| 国产午夜精品久久久| 精品国产网站地址| 91精品视频大全| 欧美成人午夜激情在线| 亚洲一区二区久久久| 91亚洲精品久久久| 欧美日韩国产在线播放| 91在线|亚洲| 国产一区玩具在线观看| 国产精品va在线播放我和闺蜜| 中文精品99久久国产香蕉| 国产成人精彩在线视频九色| 日韩欧美精品免费在线| 九九精品在线播放| 久热99视频在线观看| 日韩中文字幕免费视频| 国产精品久久久久久久电影| 色老头一区二区三区在线观看| 日韩福利伦理影院免费| 亚洲精品国产美女| 一区二区三区动漫| 日韩免费观看视频| 成人h猎奇视频网站| 精品国产乱码久久久久久虫虫漫画| 久久91超碰青草是什么| 欧美精品一区二区免费| 久久亚洲综合国产精品99麻豆精品福利| 亚洲影院高清在线| 中文字幕成人在线| 日本韩国欧美精品大片卡二| 国产欧洲精品视频| 亚洲精品自拍第一页| 亚洲国产成人一区| 亚洲图中文字幕| 欧美与欧洲交xxxx免费观看| 亚洲第一黄色网| 久久久噜久噜久久综合| 国内精品一区二区三区四区| 欧美激情视频网站| 久久久999精品免费| 欧洲成人在线视频| 国产精品白丝av嫩草影院| 91情侣偷在线精品国产| 欧美性69xxxx肥| 亚洲韩国欧洲国产日产av| 日本亚洲欧洲色α| 久久精品国产96久久久香蕉| 亚洲视频axxx| 动漫精品一区二区| 亚洲精品白浆高清久久久久久| 日韩中文在线不卡| 久久躁狠狠躁夜夜爽| 18一19gay欧美视频网站| 成人动漫网站在线观看| 中文字幕亚洲色图| 亚洲深夜福利视频| 亚洲毛片在线看| 精品福利免费观看| 亚洲视频第一页| 亚洲影院在线看| 久久精品国产v日韩v亚洲| 热re91久久精品国99热蜜臀| 亚洲网址你懂得| 伊人久久五月天| 色综合久久久久久中文网| 久久精品国产欧美激情| 8x拔播拔播x8国产精品| 精品亚洲一区二区三区| 92版电视剧仙鹤神针在线观看| 久99九色视频在线观看| 国产精品99蜜臀久久不卡二区| 日韩美女写真福利在线观看| 亚洲天堂影视av| 国产精品尤物福利片在线观看| 欧美在线视频在线播放完整版免费观看| 国产精品最新在线观看| 欧美激情xxxx性bbbb| 日本免费久久高清视频| 成人精品一区二区三区电影黑人| 欧美区在线播放| 亚洲第一色在线| 久久91亚洲人成电影网站| 影音先锋欧美精品| 97国产真实伦对白精彩视频8| 久久91精品国产91久久跳| 在线看欧美日韩| 日韩精品视频在线观看免费| 91精品一区二区| 欧美大秀在线观看| 黄色成人av网| 2019亚洲男人天堂| 日韩电影第一页| 久久全球大尺度高清视频| 亚洲日韩中文字幕| 精品国产一区av| 亚洲男人天堂网| 色综合导航网站| 欧美激情免费在线| 欧美性极品xxxx做受| 日本久久久久久久| 丝袜美腿精品国产二区| 日韩在线观看免费av| 国产视频观看一区| 亚洲资源在线看| 欧美大片大片在线播放| 午夜精品久久久久久久白皮肤| 日韩美女免费视频| 久久91超碰青草是什么| 成人免费淫片aa视频免费| 国产精彩精品视频| 成人在线中文字幕| 动漫精品一区二区| 亚洲一区av在线播放| 91久久久久久久久久久久久| 日韩一区二区在线视频| 亚洲女同精品视频| 欧美孕妇性xx| 91av免费观看91av精品在线| 亚洲成人精品视频| 国产精品国产三级国产专播精品人|