PDO是一个“数据库访问抽象层”,作用是统一各种数据库的访问接口,与mysql和mysqli的函数库相比,PDO让跨数据库的使用更具有亲和力;与ADODB和MDB2相比,PDO更高效。
-
目前而言,实现“数据库抽象层”任重而道远,使用PDO这样的“数据库访问抽象层”是一个不错的选择。
PDO中包含三个预定义的类
PDO中包含三个预定义的类,它们分别是 PDO、PDOStatement 和 PDOException。
一、PDO
PDO->beginTransaction() — 标明回滚起始点
PDO->commit() — 标明回滚结束点,并执行SQL
PDO->__construct() — 建立一个PDO链接数据库的实例
PDO->errorCode() — 获取错误码
PDO->errorInfo() — 获取错误的信息
PDO->exec() — 处理一条SQL语句,并返回所影响的条目数
PDO->getAttribute() — 获取一个“数据库连接对象”的属性
PDO->getAvailableDrivers() — 获取有效的PDO驱动器名称
PDO->lastInsertId() — 获取写入的最后一条数据的主键值
PDO->prepare() — 生成一个“查询对象”
PDO->query() — 处理一条SQL语句,并返回一个“PDOStatement”
PDO->quote() — 为某个SQL中的字符串添加引号
PDO->rollBack() — 执行回滚
PDO->setAttribute() — 为一个“数据库连接对象”设定属性
二、PDOStatement
pdostatement - > bindcolumn()绑定列一个变量
pdostatement - > bindparam() -绑定一个参数指定的变量名
pdostatement - > bindvalue() -绑定值参数
pdostatement - > closecursor() -关闭游标,使语句再次执行。
pdostatement - > columncount() -返回多个结果集中的列
pdostatement - > errorcode() -取SQL STATE与最后一次操作的语句句柄
pdostatement - > errorinfo() -获取扩展错误信息与上一次操作的语句句柄
pdostatement - > execute() -一份声明
pdostatement - > fetch() -读取下一行的结果集
pdostatement - > fetchall() -返回一个数组包含所有行的结果集
pdostatement - > fetchcolumn()返回一列从下一行的结果集
pdostatement - > fetchobject() -读取下一行并返回对象。
pdostatement - > getattribute() -检索表属性
pdostatement - > getcolumnmeta()返回元数据的列在一个结果集
pdostatement - > nextrowset() -进展到下一个行集在multi-rowset语句句柄
pdostatement - > rowcount() -返回受影响的行数的最后的语句
pdostatement - > setattribute() -设置一个声明属性
pdostatement - > setfetchmode() -设置默认提取模式这一声明
PDO是一个“数据库访问抽象层”,作用是统一各种数据库的访问接口,与mysql和mysqli的函数库相比,PDO让跨数据库的使用更具有亲和力;与ADODB和MDB2相比,PDO更高效。目前而言,实现“数据库抽象层”任重而道远,使用PDO这样的“数据库访问抽象层”是一个不错的选择。
PDO中包含三个预定义的类
PDO中包含三个预定义的类,它们分别是 PDO、PDOStatement 和 PDOException。
一、PDO
PDO->beginTransaction() — 标明回滚起始点
PDO->commit() — 标明回滚结束点,并执行SQL
PDO->rollBack() — 执行回滚
PDO->__construct() — 建立一个PDO链接数据库的实例
PDO->errorCode() — 获取错误码
PDO->errorInfo() — 获取错误的信息
PDO->exec() — 处理一条SQL语句,并返回所影响的条目数
PDO->getAttribute() — 获取一个“数据库连接对象”的属性
PDO->getAvailableDrivers() — 获取有效的PDO驱动器名称
PDO->lastInsertId() — 获取写入的最后一条数据的主键值
PDO->prepare() — 生成一个“查询对象”
PDO->query() — 处理一条SQL语句,并返回一个“PDOStatement”
PDO->quote() — 为某个SQL中的字符串添加引号
PDO->setAttribute() — 为一个“数据库连接对象”设定属性
详解1) PDO中的数据库连接
$dsn = ‘mysql:dbname=ent;host=127.0.0.1′;
$user = ‘root';
$password = ‘123456′;
try {
$dbh = new PDO($dsn, $user, $password, array(PDO::ATTR_PERSISTENT => true));
$dbh->query('set names utf8;');
foreach ($dbh->query('SELECT * from tpm_juese') as $row) {
print_r($row);
}
} catch (PDOException $e) {
echo ‘Connection failed: ‘ . $e->getMessage();
}
许多Web应用会因为使用了向数据库的持久连接而得到优化。持久连接不会在脚本结束时关闭,
相反它会被缓存起来并在另一个脚本通过同样的标识请求一个连接时得以重新利用。
持久连接的缓存可以使你避免在脚本每次需要与数据库对话时都要部署一个新的连接的资源消耗,让你的Web应用更加快速。
上面实例中的array(PDO::ATTR_PERSISTENT => true)就是把连接类型设置为持久连接。
详解2) PDO中的事务
PDO->beginTransaction(),PDO->commit(),PDO->rollBack()这三个方法是在支持回滚功能时一起使用的。PDO->beginTransaction()方法标明起始点,PDO->commit()方法标明回滚结束点,并执行SQL,PDO->rollBack()执行回滚。
<?php
try {
$dbh = new PDO('mysql:host=localhost;dbname=test', ‘root', ”);
$dbh->query('set names utf8;');
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->beginTransaction();
$dbh->exec(”INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('mick', 22);”);
$dbh->exec(”INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('lily', 29);”);
$dbh->exec(”INSERT INTO `test`.`table` (`name` ,`age`)VALUES ('susan', 21);”);
$dbh->commit();
} catch (Exception $e) {
$dbh->rollBack();
echo “Failed: ” . $e->getMessage();
}
?>
现在你已经通过PDO建立了连接,在部署查询之前你必须搞明白PDO是怎样管理事务的。如果你以前从未遇到过事务处理,(现在简单介绍一下:)它们提供了4个主要的特性:原子性,一致性,独立性和持久性(Atomicity, Consistency, Isolation and Durability,ACID)通俗一点讲,一个事务中所有的工作在提交时,即使它是分阶段执行的,也要保证安全地应用于数据库,不被其他的连接干扰。事务工作也可以在请求发生错误时轻松地自动取消。
事务的典型运用就是通过把批量的改变“保存起来”然后立即执行。这样就会有彻底地提高更新效率的好处。换句话说,事务可以使你的脚本更快速同时可能更健壮(要实现这个优点你仍然需要正确的使用它们)。
不幸运的是,并不是每个数据库都支持事务,因此PDO需要在建立连接时运行在被认为是“自动提交”的模式下。自动提交模式意味着你执行的每个查询都有它自己隐含的事务处理,无论数据库支持事务还是因数据库不支持而不存在事务。如果你需要一个事务,你必须使用 PDO->beginTransaction() 方法创建一个。如果底层驱动不支持事务处理,一个PDOException就会被抛出(与你的异常处理设置无关,因为这总是一个严重的错误状态)。在一个事物中,你可以使用 PDO->commit() 或 PDO->rollBack() 结束它,这取决于事务中代码运行是否成功。
当脚本结束时或一个连接要关闭时,如果你还有一个未处理完的事务,PDO将会自动将其回滚。这是对于脚本意外终止的情况来说是一个安全的方案——如果你没有明确地提交事务,它将会假设发生了一些错误,为了你数据的安全,所以就执行回滚了。
二、PDOStatement
PDOStatement->bindColumn() — Bind a column to a PHP variable
PDOStatement->bindParam() — Binds a parameter to the specified variable name
PDOStatement->bindValue() — Binds a value to a parameter
PDOStatement->closeCursor() — Closes the cursor, enabling the statement to be executed again.
PDOStatement->columnCount() — Returns the number of columns in the result set
PDOStatement->errorCode() — Fetch the SQLSTATE associated with the last operation on the statement handle
PDOStatement->errorInfo() — Fetch extended error information associated with the last operation on the statement handle
PDOStatement->execute() — Executes a prepared statement
PDOStatement->fetch() — Fetches the next row from a result set
PDOStatement->fetchAll() — Returns an array containing all of the result set rows
PDOStatement->fetchColumn() — Returns a single column from the next row of a result set
PDOStatement->fetchObject() — Fetches the next row and returns it as an object.
PDOStatement->getAttribute() — Retrieve a statement attribute
PDOStatement->getColumnMeta() — Returns metadata for a column in a result set
PDOStatement->nextRowset() — Advances to the next rowset in a multi-rowset statement handle
PDOStatement->rowCount() — Returns the number of rows affected by the last SQL statement
PDOStatement->setAttribute() — Set a statement attribute
PDOStatement->setFetchMode() — Set the default fetch mode for this statement
三、PDOException
PDO 提供了3中不同的错误处理策略。
1. PDO::ERRMODE_SILENT
这是默认使用的模式。PDO会在statement和database对象上设定简单的错误代号,你可以使用PDO->errorCode() 和 PDO->errorInfo() 方法检查错误;如果错误是在对statement对象进行调用时导致的,你就可以在那个对象上使用 PDOStatement->errorCode() 或 PDOStatement->errorInfo() 方法取得错误信息。而如果错误是在对database对象调用时导致的,你就应该在这个database对象上调用那两个方法。
2. PDO::ERRMODE_WARNING
作为设置错误代号的附加,PDO将会发出一个传统的E_WARNING信息。这种设置在除错和调试时是很有用的,如果你只是想看看发生了什么问题而不想中断程序的流程的话。
3. PDO::ERRMODE_EXCEPTION
作为设置错误代号的附件,PDO会抛出一个PDOException异常并设置它的属性来反映错误代号和错误信息。这中设置在除错时也是很有用的,因为他会有效的“放大(blow up)”脚本中的出错点,非常快速的指向一个你代码中可能出错区域。(记住:如果异常导致脚本中断,事务处理回自动回滚。)
异常模式也是非常有用的,因为你可以使用比以前那种使用传统的PHP风格的错误处理结构更清晰的结构处理错误,比使用安静模式使用更少的代码及嵌套,也能够更加明确地检查每个数据库访问的返回值。
关于PHP中异常的更多信息请看Exceptions章节
PDO 使用基于SQL-92 SQLSTATE 的错误代号字符串;特定的PDO驱动应当将自己本身的代号对应到适当的SQLSTATE代号上。PDO->errorCode() 方法只返回单一的SQLSTATE代号。如果你需要关于一个错误的更加有针对性的信息,PDO也提供了一个PDO->errorInfo()方法,它可以返回一个包含了SQLSTATE代号,特定数据库驱动的错误代号和特定数据库驱动的错误说明字符串。
<?php
// 修改默认的错误显示级别
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);
?>
属性列表:
PDO::PARAM_BOOL
表示一个布尔类型
PDO::PARAM_NULL
表示一个SQL中的NULL类型
PDO::PARAM_INT
表示一个SQL中的INTEGER类型
PDO::PARAM_STR
表示一个SQL中的SQL CHAR,VARCHAR类型
PDO::PARAM_LOB
表示一个SQL中的large object类型
PDO::PARAM_STMT
表示一个SQL中的recordset类型,还没有被支持
PDO::PARAM_INPUT_OUTPUT
Specifies that the parameter is an INOUT parameter for a stored procedure. You must bitwise-OR this value with an explicit PDO::PARAM_* data type.
PDO::FETCH_LAZY
将每一行结果作为一个对象返回
PDO::FETCH_ASSOC
仅仅返回以键值作为下标的查询的结果集,名称相同的数据只返回一个
PDO::FETCH_NAMED
仅仅返回以键值作为下标的查询的结果集,名称相同的数据以数组形式返回
PDO::FETCH_NUM
仅仅返回以数字作为下标的查询的结果集
PDO::FETCH_BOTH
同时返回以键值和数字作为下标的查询的结果集
PDO::FETCH_OBJ
以对象的形式返回结果集
PDO::FETCH_BOUND
将PDOStatement::bindParam()和PDOStatement::bindColumn()所绑定的值作为变量名赋值后返回
PDO::FETCH_COLUMN
表示仅仅返回结果集中的某一列
PDO::FETCH_CLASS
表示以类的形式返回结果集
PDO::FETCH_INTO
表示将数据合并入一个存在的类中进行返回
PDO::FETCH_FUNC
PDO::FETCH_GROUP
PDO::FETCH_UNIQUE
PDO::FETCH_KEY_PAIR
以首个键值下表,后面数字下表的形式返回结果集
PDO::FETCH_CLASSTYPE
PDO::FETCH_SERIALIZE
表示将数据合并入一个存在的类中并序列化返回
PDO::FETCH_PROPS_LATE
Available since PHP 5.2.0
PDO::ATTR_AUTOCOMMIT
在设置成true的时候,PDO会自动尝试停止接受委托,开始执行
PDO::ATTR_PREFETCH
设置应用程序提前获取的数据大小,并非所有的数据库哦度支持
PDO::ATTR_TIMEOUT
设置连接数据库超时的值
PDO::ATTR_ERRMODE
设置Error处理的模式
PDO::ATTR_SERVER_VERSION
只读属性,表示PDO连接的服务器端数据库版本
PDO::ATTR_CLIENT_VERSION
只读属性,表示PDO连接的客户端PDO驱动版本
PDO::ATTR_SERVER_INFO
只读属性,表示PDO连接的服务器的meta信息
PDO::ATTR_CONNECTION_STATUS
PDO::ATTR_CASE
通过PDO::CASE_*中的内容对列的形式进行操作
PDO::ATTR_CURSOR_NAME
获取或者设定指针的名称
PDO::ATTR_CURSOR
设置指针的类型,PDO现在支持PDO::CURSOR_FWDONLY和PDO::CURSOR_FWDONLY
PDO::ATTR_DRIVER_NAME
返回使用的PDO驱动的名称
PDO::ATTR_ORACLE_NULLS
将返回的空字符串转换为SQL的NULL
PDO::ATTR_PERSISTENT
获取一个存在的连接
PDO::ATTR_STATEMENT_CLASS
PDO::ATTR_FETCH_CATALOG_NAMES
在返回的结果集中,使用自定义目录名称来代替字段名。
PDO::ATTR_FETCH_TABLE_NAMES
在返回的结果集中,使用自定义表格名称来代替字段名。
PDO::ATTR_STRINGIFY_FETCHES
PDO::ATTR_MAX_COLUMN_LEN
PDO::ATTR_DEFAULT_FETCH_MODE
Available since PHP 5.2.0
PDO::ATTR_EMULATE_PREPARES
Available since PHP 5.1.3.
PDO::ERRMODE_SILENT
发生错误时不汇报任何的错误信息,是默认值
PDO::ERRMODE_WARNING
发生错误时发出一条php的E_WARNING的信息
PDO::ERRMODE_EXCEPTION
发生错误时抛出一个PDOException
PDO::CASE_NATURAL
回复列的默认显示格式
PDO::CASE_LOWER
强制列的名字小写
PDO::CASE_UPPER
强制列的名字大写
PDO::NULL_NATURAL
PDO::NULL_EMPTY_STRING
PDO::NULL_TO_STRING
PDO::FETCH_ORI_NEXT
获取结果集中的下一行数据,仅在有指针功能时有效
PDO::FETCH_ORI_PRIOR
获取结果集中的上一行数据,仅在有指针功能时有效
PDO::FETCH_ORI_FIRST
获取结果集中的第一行数据,仅在有指针功能时有效
PDO::FETCH_ORI_LAST
获取结果集中的最后一行数据,仅在有指针功能时有效
PDO::FETCH_ORI_ABS
获取结果集中的某一行数据,仅在有指针功能时有效
PDO::FETCH_ORI_REL
获取结果集中当前行后某行的数据,仅在有指针功能时有效
PDO::CURSOR_FWDONLY
建立一个只能向后的指针操作对象
PDO::CURSOR_SCROLL
建立一个指针操作对象,传递PDO::FETCH_ORI_*中的内容来控制结果集
PDO::ERR_NONE (string)
设定没有错误时候的错误信息
PDO::PARAM_EVT_ALLOC
Allocation event
PDO::PARAM_EVT_FREE
Deallocation event
PDO::PARAM_EVT_EXEC_PRE
Event triggered prior to execution of a prepared statement.
PDO::PARAM_EVT_EXEC_POST
Event triggered subsequent to execution of a prepared statement.
PDO::PARAM_EVT_FETCH_PRE
Event triggered prior to fetching a result from a resultset.
PDO::PARAM_EVT_FETCH_POST
Event triggered subsequent to fetching a result from a resultset.
PDO::PARAM_EVT_NORMALIZE
Event triggered during bound parameter registration allowing the driver to normalize the parameter name.
您可能感兴趣的文章:
在PHP中PDO解决中文乱码问题的一些补充
PHP5中使用PDO连接数据库的方法
封装一个PDO数据库操作类代码
PHP PDO函数库(PDO Functions)
php PDO中文乱码解决办法
PDO取Oracle lob大字段,当数据量太大无法取出的问题的解决办法
php5 pdo新改动加载注意事项
一个基于PDO的数据库操作类
详细出处参考:http://www.jb51.net/article/23237.htm
发表评论
-
Mysql——PhpMyAdmin导入大型文件(本地操作)
2015-04-09 10:59 2585使用PhpMyAdmin的时候发现大型的数据库文件(.sql ... -
清除数组中的空值,并重新排列数组键值
2013-12-13 15:21 4026//array_filter()函数的功能是利用回调函数来 ... -
关于dede后台登陆后一片空白
2012-11-17 21:01 1742今天家里的电脑上新装DEDE5.7后台登陆后竟然一片空白,装P ... -
PHP文件上传,文件格式
2012-07-24 15:02 766网上有很多php文件上传的类,文件上传处理是php的一个特色( ... -
include和require的区别
2012-07-19 11:46 1541php的require()性能与include() ... -
解决php trim无法过滤全角空格问题
2012-07-17 15:04 4671今天发现有些网上复制出来的信息标题 搜索的时候没返回结果 ... -
php 本周开始时间和结束时间;本月开始时间结束时间;上月开始时间结束时间
2012-07-11 14:10 1773<?php /** * 功能:取得给定日期所在周的 ...
相关推荐
### PHP中的PDO函数库知识点详解 #### 一、PDO简介 PDO (PHP Data Objects) 是一个数据库访问抽象层,它提供了统一的接口来访问不同类型的数据库。与传统的MySQLi或MySQL扩展相比,PDO的主要优势在于其灵活性和可...
### pdo基础函数库知识点详解 #### 一、PDO 概述 PDO (PHP Data Objects) 是 PHP 提供的一个数据访问抽象层,它提供了一个统一的接口来访问多种类型的数据库。与传统的 MySQL 和 mysqli 函数库相比,PDO 更加灵活且...
**PHP7.3的SQL Server PDO_DBLIB库详解** PDO (PHP Data Objects) 是PHP的一个扩展,它提供了一个数据访问接口,使开发者能够用统一的方式处理多种数据库。在PHP7.3版本中,PDO_DBLIB是用于连接到Microsoft SQL ...
### PHP PDO 学习笔记详解 #### 一、PDO简介 PDO(PHP Data Objects)是PHP 5中引入的一个数据库访问扩展,在PHP 6中它将成为连接数据库的标准方式,并逐步取代旧有的数据库连接方法。PDO的主要目标是为PHP提供一...
**PHP PDO 库详解** PHP PDO(PHP Data Objects)库为PHP提供了一个数据库访问抽象层,使得开发者可以使用相同的API来访问多种不同的数据库系统,如MySQL、PostgreSQL、SQLite等。这一库的设计目标是提高安全性,...
《PHP手册与函数详解》 在编程领域,PHP(Hypertext Preprocessor)是一种广泛使用的开源脚本语言,尤其在Web开发中占据了重要的地位。它以其语法简洁、学习曲线平缓而深受开发者喜爱。PHP手册作为PHP开发者的必备...
4. **函数库**:PHP有丰富的内置函数库,如字符串处理、数组操作、文件系统操作、网络通信等,这些函数库极大地简化了开发者的工作。 接下来,我们转向MySQL。MySQL是一个流行的开源关系型数据库管理系统(RDBMS)...
PHP提供了一系列的MySQLi或PDO扩展,使得开发者能够轻松地连接、查询、插入和更新数据库。例如,使用MySQLi进行数据库连接和查询: ```php <?php $servername = "localhost"; $username = "username"; $password = ...
4. **函数**:PHP提供了大量的内置函数,同时允许用户自定义函数来实现特定功能。 5. **数组**:PHP中的数组可以存储多个值,有索引数组和关联数组两种形式。 **PHP进阶** 1. **面向对象编程**:PHP5引入了完整的...
`PHP 选项及相关信息函数库.doc`文档详细介绍了PHP的配置选项,如ini设置,以及如何使用PHP内置的函数获取系统信息,如`phpinfo()`,这对于理解和调整PHP环境非常有帮助。 五、PHP开发XML应用 XML作为数据交换格式...
通过使用预处理语句、参数绑定(例如PDO和mysqli扩展)以及过滤函数(如filter_var)可以有效防止SQL注入。对于XSS攻击,可以利用htmlspecialchars和strip_tags来转义或移除不安全的HTML元素。 2. **密码存储**:...
**PHP安装包(5.1.6)详解** PHP(Hypertext Preprocessor)是一种广泛使用的开源服务器端脚本语言,特别适用于Web开发,并可嵌入到HTML中。PHP 5.1.6是该语言的一个历史版本,发布于2007年,虽然现在已经被更现代...
### 学习PHP数据对象(PDO):数据库连接抽象库详解 #### 引言 《学习PHP数据对象》是一本由Dennis Popel撰写的专著,深入探讨了PHP Data Objects (PDO)这一主题,旨在为读者提供一个全面且深入的理解PHP与数据库...
4. **改进的函数库**:PHP5对内置函数进行了大量优化和扩展,增强了对XML、PDF、ZIP等格式的支持。 MySQL5是广泛使用的开源关系型数据库管理系统,其关键特性有: 1. **事务处理**:MySQL5支持ACID(原子性、一致性...
4. **扩展库**:介绍各种扩展模块,如MySQLi、PDO(PHP Data Objects)、XML处理、加密函数等。 5. **附录**:包含一些实用信息,如常量列表、预定义变量、错误和异常代码等。 **PHP-chunked-xhtml文件** 在提供...
PHP作为一种动态类型的语言,其丰富的内置函数库是其强大之处,下面我们将深入探讨PHP服务函数的相关知识点。 1. **错误和异常处理** PHP提供了`error_reporting()`、`set_error_handler()`和`trigger_error()`等...
学习PHP不仅涉及安装过程,还需要掌握其语法特性、函数库、面向对象编程、MVC框架(如Laravel、Symfony)、数据库操作(MySQLi或PDO)、Web服务接口(如RESTful API)、模板引擎等。同时,熟悉常用的PHP开发工具,如...