住【PDO是啥】

PDO是PHP5新加入的一个重大功能,因为在PHP5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接和处理,什么php_mysql.dll、php_pgsql.dll、php_mssql.dll、php_sqlite.dll等等扩展来连接MySQL、PostgreSQL、MSSQLServer、SQLite,同样的,我们必须借助ADOdb、PEAR:B、PHPlib:B之类的数据库抽象类来帮助我们,无比烦琐和低效,毕竟,php代码的效率怎么能够我们直接用C/C++写的扩展斜率高捏?所以嘛,PDO的出现是必然的,大家要平静学习的心态去接受使用,也许你会发现能够减少你不少功夫哦。

【安装PDO】

我是在WindowsXPSP2上面,所以嘛,整个过程都是在Windows行进行的啦,至于Linux/FreeBSD等平台,请自行查找资料设置安装。
我的是PHP5.1.4,已经自带有了php_pdo.dll的扩展,不过需要稍微设置一下才能使用。 打开c:\windows\php.ini,那是我的PHP配置文件,找到下面这行: extension_dir 这个就是我们扩展存在的目录,我的PHP5扩展是在:C:\php5\ext,那么我就把这行改成: extension_dir="C:/php5/ext" 上面这个在做PHP环境时都已修改好了,就不用再改了. 然后再往wq 下面找到: ;;;;;;;;;;;;;;;;;;;;;;
;DynamicExtensions;
;;;;;;;;;;;;;;;;;;;;;; 下面有一堆类似;extension=php_mbstring.dll的东西,这里就是PHP扩展加载的配置了,我们再最后面添加上我们PDO的扩展: extension=php_pdo.dll
extension=php_pdo_mysql.dll
extension=php_pdo_pgsql.dll
extension=php_pdo_sqlite.dll
extension=php_pdo_mssql.dll
extension=php_pdo_odbc.dll
extension=php_pdo_firebird.dll
;extension=php_pdo_oci8.dll
各种PDO的驱动,能给加上的全给加上,不过后面的php_pdo_oci8.dll,因为我没有安装Oralce数据库,所以没有这个,就使用分号注释掉它。然后重启我们的Web服务器,IIS/Apache,我的是IIS,嘿嘿,表鄙视我,在Windows上,简单嘛。 重启后,在我们Web服务器的文档目录下写一个phpinfo.php的文件,加上这些: <?
 phpinfo();
?>
然后打开我们可爱的浏览器:IE/FireFox,我的是FireFox2.,刚下载的,很爽,不怕流氓软件,哈哈。 在浏览器里面输入:http://localhost/phpinfo.php,如果你的这个页面路径不一致,请自行输入。 输出的内容中,如果你能够顺利的看到: PDO
PDOsupportenabled
PDOdriversmysql,pgsql,sqlite,mssql,odbc,firebird
后面有各种驱动的说明:PDO_Firebird,pdo_mssql,pdo_mysql,PDO_ODBC,pdo_pgsql,pdo_sqlite 那么,恭喜你安装成功了,否则请仔细检查上面的步骤。 【牛刀小小试】 我用的是MySQL4.0.26,但是我个人推荐大家使用MySQL4..x或者MySQL5..x,因为那些版本有很多有趣的东西值得去学习。我们这里PDO需要连接的就是我的MySQL4.0啦,如果你没有安装MySQL,请自行安装。我们建立好了MySQL,并且在test库里添加了表foo,包括id,name,gender,time等四个字段。 我们开始构造第一个PDO应用,建立一个pdo.php文件在Web文档目录下: <?php
 $dsn="mysql:host=localhost;dbname=test";
 $db=newPDO($dsn,'root','');
 $count=$db->exec("INSERTINTOfooSETname='heiyeluren',gender='男',time=NOW()");
 echo$count;
 $db=null;
?>
不明白啥意思,俺们来慢慢讲讲。这行: $dsn="mysql:host=localhost;dbname=test";
就是构造我们的DSN(数据源),看看里面的信息包括:数据库类型是mysql,主机地址是localhost,数据库名称是test,就这么几个信息。不同数据库的数据源构造方式是不一样的。 $db=newPDO($dsn,'root','');
初始化一个PDO对象,构造函数的参数第一个就是我们的数据源,第二个是连接数据库服务器的用户,第三个参数是密码。我们不能保证连接成功,后面我们会讲到异常情况,这里我们姑且认为它是连接成功的。 $count=$db->exec("INSERTINTOfooSETname='heiyeluren',gender='男',time=NOW()");
echo$count;
调用我们连接成功的PDO对象来执行一个查询,这个查询是一个插入一条记录的操作,使用PDO::exec()方法会返回一个影响记录的结果,所以我们输出这个结果。最后还是需要结束对象资源: $db=null;
默认这个不是长连接,如果需要数据库长连接,需要最后加一个参数:array(PDO::ATTR_PERSISTENT=>true)变成这样: $db=newPDO($dsn,'root','',array(PDO::ATTR_PERSISTENT=>true)); 一次操作就这么简单,也许跟以前的没有太大区别,跟ADOdb倒是有几分相似。 【继续了解】 如果我们想提取数据的话,那么就应该使用数据获取功能。(下面用到的$db都是上面已经连接好的对象) <?php
 foreach($db->query("SELECT*FROMfoo")){
print_r($row);
 }
?>
我们也可以使用这种获取方式: <?php
 $rs=$db->query("SELECT*FROMfoo");
 while($row=$rs->fetch()){
print_r($row);
 }
?>
如果想一次把数据都获取到数组里可以这样: <?php
$rs=$db->query("SELECT*FROMfoo");
$result_arr=$rs->fetchAll();
print_r($result_arr);
?> Array
([]=>Array(
 [id]=>
 []=>
 [name]=>heiyeluren
 []=>heiyeluren
 [gender]=>男
 []=>男
 [time]=>--::
 []=>--::
)
}
我们看里面的记录,数字索引和关联索引都有,浪费资源,我们只需要关联索引的: <?php
$db->setAttribute(PDO::ATTR_CASE,PDO::CASE_UPPER);
$rs=$db->query("SELECT*FROMfoo");
$rs->setFetchMode(PDO::FETCH_ASSOC);
$result_arr=$rs->fetchAll();
print_r($result_arr);
?>
看上面的代码,setAttribute()方法是设置部分属性,主要属性有:PDO::ATTR_CASE、PDO::ATTR_ERRMODE等等,我们这里需要设置的是PDO::ATTR_CASE,就是我们使用关联索引获取数据集的时候,关联索引是大写还是小写,有几个选择: PDO::CASE_LOWER--强制列名是小写
PDO::CASE_NATURAL--列名按照原始的方式
PDO::CASE_UPPER--强制列名为大写 我们使用setFetchMode方法来设置获取结果集的返回值的类型,同样类型还有: PDO::FETCH_ASSOC--关联数组形式
PDO::FETCH_NUM--数字索引数组形式
PDO::FETCH_BOTH--两者数组形式都有,这是缺省的
PDO::FETCH_OBJ--按照对象的形式,类似于以前的mysql_fetch_object() 当然,一般情况下我们是使用PDO::FETCH_ASSOC,具体使用什么,按照你自己的需要,其他获取类型参考手册。 除了上面这种获取数据的方式,还有这种: <?php
$rs=$db->prepare("SELECT*FROMfoo");
$rs->execute();
while($row=$rs->fetch()){
 print_r($row);
}
?>
其实差不多啦。如果你想获取指定记录里一个字段结果的话,可以使用PDOStatement::fetchColumn(): <?php
$rs=$db->query("SELECTCOUNT(*)FROMfoo");
$col=$rs->fetchColumn();
echo$col;
?>
一般使用fetchColumn()来进行count统计或者某些只需要单字段的记录很好操作。 简单的总结一下上面的操作: 查询操作主要是PDO::query()、PDO::exec()、PDO::prepare()。PDO::query()主要是用于有记录结果返回的操作,特别是SELECT操作,PDO::exec()主要是针对没有结果集合返回的操作,比如INSERT、UPDATE、DELETE等操作,它返回的结果是当前操作影响的列数。PDO::prepare()主要是预处理操作,需要通过$rs->execute()来执行预处理里面的SQL语句,这个方法可以绑定参数,功能比较强大,不是本文能够简单说明白的,大家可以参考手册和其他文档。获取结果集操作主要是:PDOStatement::fetchColumn()、PDOStatement::fetch()、PDOStatement::fetchALL()。PDOStatement::fetchColumn()是获取结果指定第一条记录的某个字段,缺省是第一个字段。PDOStatement::fetch()是用来获取一条记录,PDOStatement::fetchAll()是获取所有记录集到一个中,获取结果可以通过PDOStatement::setFetchMode来设置需要结果集合的类型。 另外有两个周边的操作,一个是PDO::lastInsertId()和PDOStatement::rowCount()。PDO::lastInsertId()是返回上次插入操作,主键列类型是自增的最后的自增ID。PDOStatement::rowCount()主要是用于PDO::query()和PDO::prepare()进行DELETE、INSERT、UPDATE操作影响的结果集,对PDO::exec()方法和SELECT操作无效。 【错误处理】 如果程序中碰到错误咋办?我们这里描述PDO类的错误信息和异常处理。 .面向对象的方式 先看看如果连接错误等的处理,使用面向对象的方式来处理: <?php
try{
 $db=newPDO('mysql:host=localhost;dbname=test',$user,$pass);
 $db=null;
}catch(PDOException$e){
 print"Error:".$e->getMessage()."<br/>";
 die();
}
?>
这里利用我们PHP5面向对象的异常处理特征,如果里面有异常的话就初始化调用PDOException来初始化一个异常类。 PDOException异常类的属性结构: <?php
classPDOExceptionextendsException
{
 public$errorInfo=null;//错误信息,可以调用PDO::errorInfo()或PDOStatement::errorInfo()来访问
 protected$message;//异常信息,可以试用Exception::getMessage()来访问
 protected$code;//SQL状态错误代码,可以使用Exception::getCode()来访问
}
?>
这个异常处理类是集成PHP5内置的异常处理类,我们简单的看一下PHP5内置的异常处理类结构: <?php
classException
{
 //属性
 protected$message='Unknownexception';//异常信息
 protected$code=;//用户自定义异常代码
 protected$file;//发生异常的文件名
 protected$line;//发生异常的代码行号  //方法
 finalfunctiongetMessage();//返回异常信息
 finalfunctiongetCode();//返回异常代码
 finalfunctiongetFile();//返回发生异常的文件名
 finalfunctiongetLine();//返回发生异常的代码行号
 finalfunctiongetTrace();//backtrace()数组
 finalfunctiongetTraceAsString();//已格成化成字符串的getTrace()信息
}
?>
相应的,在代码中可以合适的调用getFile()和getLine()来进行错误定位,更方便的进行调试。 .使用面向过程的方法 先看代码: <?
$db=newPDO('mysql:host=localhost;dbname=test',$user,$pass);
$rs=$db->query("SELECTaa,bb,ccFROMfoo");
if($db->errorCode()!=''){
 print_r($db->errorInfo());
 exit;
}
$arr=$rs->fetchAll();
print_r($arr);
$db=null;
?>
PDO和PDOStatement对象有errorCode()和errorInfo()方法,如果没有任何错误,errorCode()返回的是:,否则就会返回一些错误代码。errorInfo()返回的一个数组,包括PHP定义的错误代码和MySQL的错误代码和错误信息,数组结构如下: Array
(
 []=>42S22
 []=>
 []=>Unknowncolumn'aaa'in'fieldlist'
)
每次执行查询以后,errorCode()的结果都是最新的,所以我们可以很容易自己控制错误信息显示。 【简单总结】 从上面的使用看出,PDO功能确实强大,另外还有一些内容我没有讲到,比如绑定参数、预处理、存储过程、事务处理等等功能。另外还有不同数据扩DSN的构造,Oracle数据库自己很多特殊的东西,都需要深入去学习理解,这篇文章就只是简单的描述了一些入门知识,算是对PDO一个简单的了解吧。 (操作很简单:
打开c:\windows\php.ini文件 找到下面有一堆类似;extension=php_mbstring.dll的东西,这里就是PHP扩展加载的配置了,我们再最后面添加上我们PDO的扩展: extension=php_pdo.dll
extension=php_pdo_mysql.dll
extension=php_pdo_pgsql.dll
extension=php_pdo_sqlite.dll
extension=php_pdo_mssql.dll
extension=php_pdo_odbc.dll
extension=php_pdo_firebird.dll
;extension=php_pdo_oci8.dll 最后重启IIS/Apache.OK.)

注:想要使用PDO配置那个数据库,就将php.ini文件中前面的分号去掉,然后重启。

PHP中PDO的配置与说明的更多相关文章

  1. PHP5中PDO的简单使用

    PHP5中PDO的简单使用 标签: php数据库mysql扩展extensionexception 2012-05-06 10:27 27753人阅读 评论(0) 收藏 举报  分类: PHP(6)  ...

  2. pdo 的配置与启用

    PDO(PHP Data Object)扩展在PHP5中加入,PHP6中将默认识用PDO连接数据库,所有非PDO扩展将会在PHP6被从扩展中移除.该扩展提供PHP内置类 PDO来对数据库进行 访问,不 ...

  3. WCF学习之旅—WCF4.0中的简化配置功能(十五)

    六 WCF4.0中的简化配置功能 WCF4.0为了简化服务配置,提供了默认的终结点.绑定和服务行为.也就是说,在开发WCF服务程序的时候,即使我们不提供显示的 服务终结点,WCF框架也能为我们的服务提 ...

  4. asp.net中web.config配置节点大全详解

    最近网上找了一些关于Web.config配置节点的文章,发现很多都写的都比较零散,而且很少有说明各个配置节点的作用和用法.搜索了一下发现有一篇写的不错,这里引用一下 原文地址 http://www.c ...

  5. CentOS-7.0.中安装与配置Tomcat-7的方法

    安装说明 安装环境:CentOS-7.0.1406安装方式:源码安装 软件:apache-tomcat-7.0.29.tar.gz 下载地址:http://tomcat.apache.org/down ...

  6. 在Web.config或App.config中的添加自定义配置

    .Net中的System.Configuration命名空间为我们在web.config或者app.config中自定义配置提供了完美的支持.最近看到一些项目中还在自定义xml文件做程序的配置,所以忍 ...

  7. IIS7错误:不能在此路径中使用此配置节。如果在父级别上锁定了该节,便会出现这种情况。锁定是默认设置的(overrideModeDefault="Deny")......

    不能在此路径中使用此配置节.如果在父级别上锁定了该节,便会出现这种情况.锁定是默认设置的(overrideModeDefault="Deny")...... 解决方案: 因为 II ...

  8. 深入理解php中的ini配置(1)

    这篇文章不会详细叙述某个ini配置项的用途,这些在手册上已经讲解的面面俱到.我只是想从某个特定的角度去挖掘php的实现机制,会涉及到一些php内核方面的知识:-) 使用php的同学都知道php.ini ...

  9. IIS关于“ 配置错误 不能在此路径中使用此配置节”的解决办法

    IIS关于“ 配置错误 不能在此路径中使用此配置节”的解决办法 原文链接:http://www.cnblogs.com/200325074/p/3679316.html 今天刚安装好IIS8.5, 我 ...

随机推荐

  1. Quartz.net打造信息抽取器

    由于最近的一个项目需要定时抽取特定XML信息,然后保存到数据库,最后通过WebApi把手机端要使用的方法给暴露出来,所以去研究了一下Quartz.net.由于项目很小,我没用到Autofac,Repo ...

  2. 基于React Native的Material Design风格的组件库 MRN

    基于React Native的Material Design风格的组件库.(为了平台统一体验,目前只打算支持安卓) 官方网站 http://mrn.js.org/ Github https://git ...

  3. LeetCode:Convert Sorted Array to Binary Search Tree,Convert Sorted List to Binary Search Tree

    LeetCode:Convert Sorted Array to Binary Search Tree Given an array where elements are sorted in asce ...

  4. LeetCode 笔记28 Maximum Gap

    Given an unsorted array, find the maximum difference between the successive elements in its sorted f ...

  5. 学习bash

    工作8年,前6年基本是Windows环境下,也就是个鼠标党:两年前换工作开始用linux,也就开始了领略了命令行的强大,无论是直接在命令行组合命令,也还写几行简单的shell脚本,其能完成的功能往往令 ...

  6. C#基础之枚举

    1.认识Enum 以前一直以为Enum是值类型,在VS中查看Enum的定义时才发现它是一个抽象的类.但是这个类很奇怪,Enum继承了ValueType这个很熟悉的值类型基类,它是唯一一个继承自Valu ...

  7. Windows Phone 开发——相机功能开发

    相机功能是手机区别于PC的一大功能,在做手机应用时,如果合理的利用了拍照功能,可能会给自己的应用增色很多.使用Windows Phone的相机功能,有两种方法,一种是使用PhotoCamera类来构建 ...

  8. 如何用Android Studio打多包名APK

    问题:项目中不同的分发渠道可能需要打包多种APK(同样的代码),包名可能是不一样的,如果一个一个修改包名重新编apk是很麻烦,可以参考下列步骤在Android Studio上操纵Gradle来打包不同 ...

  9. jsp中常用操作字符串的el表达式

    由于在JSP页面中显示数据时,经常需要对显示的字符串进行处理,SUN公司针对于一些常见处理定义了一套EL函数库供开发者使用. 准备工作:1)导入jar包:standard.jar和jstl.jar2) ...

  10. FTP+SFTP工具类封装-springmore让开发更简单

    github地址:https://github.com/tangyanbo/springmore FTPUtil 该工具基于org.apache.commons.net.ftp.FTPClient进行 ...