首頁 >後端開發 >php教程 >PHP連接到mysql的方法-mysqli和PDO

PHP連接到mysql的方法-mysqli和PDO

不言
不言原創
2018-04-09 17:11:433358瀏覽

這篇文章給大家分享的內容是PHP連接到mysql的方法-mysqli和PDO,有需要的朋友可以參考一下

看書的時候提及了PDO擴展連接資料庫,之前一直用的mysql擴充和mysqli擴展,基本上沒用PDO,所以查了一些資料,特地記錄轉載,

PHP的MySQL擴充(優缺點)

設計開發允許PHP應用與MySQL資料庫互動的早期擴充。 mysql擴充提供了一個流程導向的介面;

並且是針對MySQL4.1.3或更早版本設計的。因此,這個擴充雖然可以與MySQL4.1.3或更新的數 ;

據函式庫服務端 進行交互,但並不支援後期MySQL服務端提供的一些特性。

PHP的mysqli擴展

mysqli擴展,我們有時稱為MySQL增強擴展,可以用於使用MySQL4.1.3或更新版本中新的高級特性;

# mysqli擴充在PHP 5及以後版本中包含;

mysqli擴充有一系列的優勢,相對於mysql擴充的提升主要有:物件導向介面、 prepared語句支援、多語句執行支援、交易支援、增強的調試能力、嵌入式服務支援。

PHP資料對象(PDO)

PHP資料對象,是PHP應用中的一個資料庫抽象層規格。 PDO提供了一個統一的API介面可以,讓你的PHP應用不關心具體要 連接的資料庫伺服器系統類型。也就是說,如果你使用PDO的API,可以在任何需要的時候無縫切換資料庫伺服器。

******************************************** ************************************************** ***********************************
PHP-MySQL 是PHP 操作MySQL 資料庫最原始的Extension ,PHP-MySQLi 的i 代表Improvement ,

提更了相對進階的功能,就Extension 而言,本身也增加了安全性。

而 PDO (PHP Data Object) 則是提供了一個 Abstraction Layer 來操作資料庫


1.mysql與mysqli

mysqli是php5提供的新函數庫,(i)表示改進,其執行速度更快.當然也更安全

mysql是非持繼連接函數而mysqli是永遠連接函數。也就是說

mysql每次連結都會打開一個連接的進程而mysqli多次運行mysqli將使用同一連接進程,從而減少了伺服器的開銷有些朋友在編程的時候,使用new mysqli('localhost ', usenamer', 'password', 'databasename');總是報

錯,Fatal error: Class 'mysqli' not found in d:\…

mysqli類別不是php自帶的嗎?

不是預設開啟的,win下要改php.ini,去掉php_mysqli.dll前的;,linux下要把mysqli編譯進去。

一:Mysqli.dll是一個允許以物件的方式或流程操作資料庫的,它的使用方式也很容易。


#php連接到mysql資料庫,我們一般最經典的方式就是使用mysql_connect() ,具體程式碼如下:



[php] view plain copy


mysql_connect($db_host, $db_user, $db_pass) or die(mysql_error());  
mysql_select_db($db_name);

 


##

    瀏覽器提示:本擴充自 PHP 5.5.0 起已廢棄,並在將來會被移除。應使用 MySQLi 或 PDO_MySQL## 擴充功能來取代。於是一通搜索,就有了接下來這篇文章的來源。

        這裡的mysql是一個擴充的API,目的是為了簡化php對mysql資料庫的操作

mysqli

        mysqli是mysql的一個增強版,出現在PHP 5 及以後的版本。它主要在一下幾方面比mysql增強了:

        1、面向对象接口;2、prepared语句支持(译注:关于prepare请参阅mysql相关文档);3、多语句执行支持;4、事务支持;5、增强的调试能力;6、嵌入式服务支持



[php] view plain copy


<?php   
$link = mysqli_connect("localhost","root","123456","test") or die("Error " . mysqli_error($link)); //连接,test为数据库的名称  
$query = "SELECT name FROM userInfo" or die("Error in the consult.." . mysqli_error($link));//查询  
$result = mysqli_query($link, $query);//查询的结果  
while($row = mysqli_fetch_array($result)) {   
    echo $row["name"] . "<br>";   
}  
?>


       上面的这段代码是一个完整的从连接到查询再到关闭数据库的一个例子。从该例子中可以看到,mysql_connect()和mysqli_connect()函数的用法上的小区别。




[php] view plain copy


//mysql  
mysql_connect("localhost","root","123456");  
mysql_select_db("userInfo");  
  
//mysqli  
mysqli_connect("localhost","root","123456","test");

    mysqli的连接数据库方法中除了使用上述(又称之为面向过程)之外,另外一种就是面向对象方式:



[php] view plain copy


  1. <?php  
    $mysqli = new mysqli("localhost","root","123456","test") //填写mysql用户名、密码及数据库的名称  
        or die("Could not connect to MySQL server!");  
    $mysqli->query("set names utf8"); //设置数据库内数据的编码,相当于同时设置客户端、服务器端和脚本编码方式。  
        $sql  = "select * from userInfo";  
    $result = $mysqli->query($sql);  
    if($result){  
        if($result->num_rows>0){  
            while($row =$result->fetch_array()){//循环输出结果集中的记录  
                echo ($row[0])." ";  
                echo ($row[1])." ";  
                echo ($row[2])." ";  
                echo "<br/>";  
            }  
        }  
    }else{  
        echo "Sorry!";  
    }  
    $result=NULL;   
    $mysqli->close();  
    ?>

        这种用法中,使用mysqli之前要先new一个对象,然后使用该实例对象进行操作。


PDO

    PHP的一个数据对象,它提供了一个统一的连接数据库的API,它代表的是和数据库之间的一个连接,类似于java中的jdbc。

        简单举例如下:



[php] view plain copy


<?php  
$pdo = new PDO(&#39;pgsql:host=192.168.1.111;port=5432;dbname=anydb&#39;, &#39;anyuser&#39;, &#39;pw&#39;);//连接到数据库  
sleep(5);  
$stmt = $pdo->prepare(&#39;SELECT * FROM sometable&#39;);  
$stmt->execute();  
$pdo = null;//关闭连接  
?>


         由于从PHP 6 开始要完全使用PDO方式而非其他方式连接数据库,所以接下来详细研究一番:

1、为什么要用PDO,用PDO有什么好处?


    PDO(PHP資料物件),是PHP存取資料庫的一個輕量級的統一介面。它提供了一個資料存取抽象層,這也就是說無論什麼資料庫都能用相同的方法進行查詢或讀取。要注意的是PDO本身並不能實現任何的資料庫功能,而是必須要使用一個具體資料庫的PDO驅動器進行存取資料庫服務。

2、怎麼用PDO?

     這裡我們就以PHP的黃金搭檔mysql當範例來看:

#     PDO_MYSQL:PDO_MYSQL是PDO介面能夠完成連接mysql資料庫的驅動程式(附註:僅使用於mysql 3.x以上版本)。

    安裝:開啟php.ini文件,可以找到以下程式碼,這裡可以看到mysql的驅動預設已經打開(前面沒有用於註釋的分號),如有連接其他資料庫的需要,自行添加其他資料庫的驅動程式(取出相應的項目前面的分號,沒有的添上)。





#[php]

 view plain

 copy

##########
  1. //各数据库的PDO驱动  
    extension=php_pdo.dll   
    extension=php_pdo_firebird.dll //Firebird  
    extension=php_pdo_informix.dll //Informix  
    extension=php_pdo_mssql.dll    //sql server  
    extension=php_pdo_mysql.dll    //mysql  
    extension=php_pdo_oci.dll      //Oracle  
    extension=php_pdo_oci8.dll   
    extension=php_pdo_odbc.dll     //DB2  
    extension=php_pdo_pgsql.dll    //PostgreSQL  
    extension=php_pdo_sqlite.dll   //SQLite

连接:通过创建PDO基类的实例创建连接。



[php] view plain copy


//连接到数据库  
$db = new PDO(&#39;mysql:host=localhost;dbname=test&#39;, $user, $pass);



[php] view plain copy


//处理连接错误  
try {  
    $db = new PDO(&#39;mysql:host=localhost;dbname=test&#39;, $user, $pass);  
    //查询  
    foreach($db->query(&#39;SELECT * from FOO&#39;) as $row) {  
        print_r($row);  
    }  
    $dbh = null;  
} catch (PDOException $e) {  
    print "Error!: " . $e->getMessage() . "<br/>";  
    die();  
}




[php] view plain copy


//关闭连接  
$db = null;

    PDO方式连接数据库mysql的实例:



[php] view plain copy


  1. <?php  
        $dbms=&#39;mysql&#39;;       //数据库 mysql  
        $host=&#39;localhost&#39;;   //数据库主机名  
        $dbName=&#39;test&#39;;      //数据库名  
        $user=&#39;root&#39;;        //连接用户名  
        $pass=&#39;&#39;;            //密码  
        $dsn="$dbms:host=$host;dbname=$dbName";  
        classdbextendsPDO{  
           publicfunction__construct(){  
                try{  
                    parent::__construct("$GLOBALS[dsn]",$GLOBALS[&#39;user&#39;],$GLOBALS[&#39;pass&#39;]);  
                 }catch(PDOException$e){  
                     die("Error: ".$e->__toString()."<br/>");  
                }  
           }  
           publicfinalfunctionquery($sql){  
                try{  
                    returnparent::query($this->setString($sql));  
                }catch(PDOException$e){  
                    die("Error: ".$e->__toString()."<br/>");  
                }  
           }  
           privatefinalfunctionsetString($sql){  
                echo"处理查询";  
                return $sql;  
           }  
        }  
        $db=new db();  
        $db->setAttribute(PDO::ATTR_CASE,PDO::CASE_UPPER);  
        foreach($db->query(&#39;select * from table_name&#39;) as $row){  
           print_r($row);  
        }  
        $db->exec(&#39;delete from table_name where id=11&#39;);  
    ?>

3、更多的PDO方法:



[php] view plain copy


PDO::beginTransaction — 启动一个事务  
PDO::commit — 提交一个事务  
PDO::__construct — 创建一个表示数据库连接的 PDO 实例  
PDO::errorCode — 获取跟数据库句柄上一次操作相关的 SQLSTATE  
PDO::errorInfo — Fetch extended error information associated with the last operation on the database handle  
PDO::exec — 执行一条 SQL 语句,并返回受影响的行数  
PDO::getAttribute — 取回一个数据库连接的属性  
PDO::getAvailableDrivers — 返回一个可用驱动的数组  
PDO::inTransaction — 检查是否在一个事务内  
PDO::lastInsertId — 返回最后插入行的ID或序列值  
PDO::prepare — Prepares a statement for execution and returns a statement object  
PDO::query — Executes an SQL statement, returning a result set as a PDOStatement object  
PDO::quote — Quotes a string for use in a query.  
PDO::rollBack — 回滚一个事务  
PDO::setAttribute — 设置属性




[php] view plain copy


PDOStatement::bindColumn — 绑定一列到一个 PHP 变量  
PDOStatement::bindParam — 绑定一个参数到指定的变量名  
PDOStatement::bindValue — 把一个值绑定到一个参数  
PDOStatement::closeCursor — 关闭游标,使语句能再次被执行。  
PDOStatement::columnCount — 返回结果集中的列数  
PDOStatement::debugDumpParams — 打印一条 SQL 预处理命令  
PDOStatement::errorCode — 获取跟上一次语句句柄操作相关的 SQLSTATE  
PDOStatement::errorInfo — 获取跟上一次语句句柄操作相关的扩展错误信息  
PDOStatement::execute — 执行一条预处理语句  
PDOStatement::fetch — 从结果集中获取下一行  
PDOStatement::fetchAll — 返回一个包含结果集中所有行的数组  
PDOStatement::fetchColumn — 从结果集中的下一行返回单独的一列。  
PDOStatement::fetchObject — 获取下一行并作为一个对象返回。  
PDOStatement::getAttribute — 检索一个语句属性  
PDOStatement::getColumnMeta — 返回结果集中一列的元数据  
PDOStatement::nextRowset — 在一个多行集语句句柄中推进到下一个行集  
PDOStatement::rowCount — 返回受上一个 SQL 语句影响的行数  
PDOStatement::setAttribute — 设置一个语句属性  
PDOStatement::setFetchMode — 为语句设置默认的获取模式。

  




[php] view plain copy


Exception::getMessage — 获取异常消息内容。  
Exception::getPrevious — 返回异常链中的前一个异常  
Exception::getCode — 获取异常代码  
Exception::getFile — 获取发生异常的程序文件名称  
Exception::getLine — 获取发生异常的代码在文件中的行号  
Exception::getTrace — 获取异常追踪信息  
Exception::getTraceAsString — 获取字符串类型的异常追踪信息  
Exception::toString — 将异常对象转换为字符串  
Exception::clone — 异常克隆

本文转自:https://blog.csdn.net/llittlepig/article/details/38272769

以上是PHP連接到mysql的方法-mysqli和PDO的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn