PDO是PHP5新加入的一个重大功能,咱们的数据库服务器为MySQL,全部的程序代码的数据库操做全是一mysql()或者mysqli()函数来操做,当咱们的数据库 须要更换时好比换成,SQLSERVER、PostgreSQL、MS 等,咱们不可能去修改全部的程序代码!因此就要用到PDO,PDO很好的帮咱们解决了这个问题,使用PDO操做很是方便,只须要修改数据源格式,和加载相应的驱动文件到PHP.ini便可;php
1)编码的一致性
因为PHP可用的各类数据库扩展是由不一样发行者编写的,因此尽管全部的扩展都提供了基本相同的特性,却不知足编码的一致性。PDO消除了这种不一致,提供了可用于各类数据库的单一接口;
2)灵活性
由于PDO在运行时加载必须的数据库驱动程序,因此不须要在每次使用不一样数据库时从新配置和从新编译PHP。例如,若是数据库须要从SQL切换到MySQL,只须要加载PDO_MYSQL驱动程序就能够了。
3)面向对象特性
PDO利用PHP5的面向对象特性,能够得到更强大、更高效的数据库通讯。
4)高性能
PDO是用C编写的,编译为PHP,与用PHP编写的其余解决方案相比,虽然其余都相同,但提供了更高的性能。mysql
经过 PHP 的 phpinfo() 函数来查看是否安装了PDO扩展。sql
添加扩展: extension=pdo.so数据库
<?php $dbms = 'mysql'; //数据库类型 $host = 'localhost'; //数据库主机名 $dbName = 'test'; //使用的数据库 $user = 'root'; //数据库链接用户名 $pass = ''; //对应的密码 $dsn = "$dbms:host=$host;dbname=$dbName"; try { $dbh = new PDO($dsn, $user, $pass); //初始化一个PDO对象 echo "链接成功<br/>"; /*你还能够进行一次搜索操做 foreach ($dbh->query('SELECT * from FOO') as $row) { print_r($row); //你能够用 echo($GLOBAL); 来看到这些值 } */ $dbh = null; } catch (PDOException $e) { die ("Error!: " . $e->getMessage() . "<br/>"); }
//默认这个不是长链接,若是须要数据库长链接,须要最后加一个参数:array(PDO::ATTR_PERSISTENT => true) 变成这样: $db = new PDO($dsn, $user, $pass, array(PDO::ATTR_PERSISTENT => true)); ?>