PDO中包含三个预定义的类,它们分别是PDO、PDOStatement和PDOException
2013-05-23 10:15
169 查看
转载自:http://blog.163.com/qj_l12@126/blog/static/35930826200962242238411/
一、PDO
代表一个PHP和数据库之间的连接
方法:
PDO - 构造器,构建一个新的PDO对象
beginTransaction - 开始事务
commit - 提交事务
errorCode - 从数据库返回一个错误代号,如果有的话
errorInfo - 从数据库返回一个含有错误信息的数组,如果有的话
exec - 执行一条SQL语句并返回影响的行数
getAttribute - 返回一个数据库连接属性
lastInsertId - 返回最新插入到数据库的行(的ID)
prepare - 为执行准备一条SQL语句
query - 执行一条SQL语句并返回一个结果集
quote - 返回添加了引号的字符串,以使其可用于SQL语句中
rollBack - 回滚一个事务
setAttribute - 设置一个数据库连接属性
方法:
bindColumn - 绑定一个PHP变量到结果集中的输出列
bindParam - 绑定一个PHP变量到一个预处理语句中的参数
bindValue - 绑定一个值到与处理语句中的参数
closeCursor - 关闭游标,使语句可以再次执行
columnCount - 返回结果集中的列的数量
errorCode - 从语句中返回一个错误代号,如果有的话
errorInfo - 从语句中返回一个包含错误信息的数组,如果有的话
execute - 执行一条预处理语句
fetch - 从结果集中取出一行
fetchAll - 从结构集中取出一个包含了所有行的数组
fetchColumn - 返回结果集中某一列中的数据
getAttribute - 返回一个 PDOStatement 属性
getColumnMeta - 返回结果集中某一列的结构(metadata?)
nextRowset - 返回下一结果集
rowCount - 返回SQL语句执行后影响的行数
setAttribute - 设置一个PDOStatement属性
setFetchMode - 为 PDOStatement 设定获取数据的方式
//PDOException类:
class PDOException extends Exception
{
// 对应 PDO::errorInfo()
// 或 PDOStatement::errorInfo()
public $errorInfo = null;
// 文本化的错误信息
// 使用Exception::getMessage() 获取它
protected $message;
// SQLSTATE 错误代号
// 使用Exception::getCode() 获取它
protected $code;
}
以上因为用到setAttribute()方法,放上那两个参数,把字段名强制转换成大写。下面列出多有PDO::setAttribute()的参数:
PDO::ATTR_CASE: 强制列名变成一种格式,详细如下(第二个参数):
PDO::CASE_LOWER: 强制列名是小写.
PDO::CASE_NATURAL: 列名按照原始的方式
PDO::CASE_UPPER: 强制列名为大写.
PDO::ATTR_ERRMODE: 错误提示.
PDO::ERRMODE_SILENT: 不显示错误信息,只显示错误码.
PDO::ERRMODE_WARNING: 显示警告错误.
PDO::ERRMODE_EXCEPTION: 抛出异常.
PDO::ATTR_ORACLE_NULLS (不仅仅是ORACLE有效,别的数据库也有效): )指定数据库返回的NULL值在php中对应的数值。
PDO::NULL_NATURAL: 不变.
PDO::NULL_EMPTY_STRING: Empty string is converted to NULL.
PDO::NULL_TO_STRING: NULL is converted to an empty string.
PDO::ATTR_STRINGIFY_FETCHES: Convert numeric values to strings when fetching. Requires bool.
PDO::ATTR_STATEMENT_CLASS: Set user-suppliedstatement class derived from PDOStatement. Cannot be used withpersistent PDO instances. Requires array(string classname, array(mixedconstructor_args)).
PDO::ATTR_AUTOCOMMIT (available in OCI, Firebird and MySQL): Whether to autocommit every single statement.
PDO::MYSQL_ATTR_USE_BUFFERED_QUERY (available in MySQL): Use buffered queries.
例子中的$rs->setFetchMode(PDO::FETCH_ASSOC);是PDOStatement::setFetchMode(),对返回类型的声明。
有如下:
PDO::FETCH_ASSOC -- 关联数组形式
PDO::FETCH_NUM -- 数字索引数组形式
PDO::FETCH_BOTH -- 两者数组形式都有,这是缺省的
PDO::FETCH_OBJ -- 按照对象的形式,类似于以前的 mysql_fetch_object()
查询操作主要是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和数据库之间的连接方法:
PDO - 构造器,构建一个新的PDO对象
beginTransaction - 开始事务
commit - 提交事务
errorCode - 从数据库返回一个错误代号,如果有的话
errorInfo - 从数据库返回一个含有错误信息的数组,如果有的话
exec - 执行一条SQL语句并返回影响的行数
getAttribute - 返回一个数据库连接属性
lastInsertId - 返回最新插入到数据库的行(的ID)
prepare - 为执行准备一条SQL语句
query - 执行一条SQL语句并返回一个结果集
quote - 返回添加了引号的字符串,以使其可用于SQL语句中
rollBack - 回滚一个事务
setAttribute - 设置一个数据库连接属性
二、PDOStatement
代表一条预处理语句以及语句执行后的联合结果集(associated result set)。方法:
bindColumn - 绑定一个PHP变量到结果集中的输出列
bindParam - 绑定一个PHP变量到一个预处理语句中的参数
bindValue - 绑定一个值到与处理语句中的参数
closeCursor - 关闭游标,使语句可以再次执行
columnCount - 返回结果集中的列的数量
errorCode - 从语句中返回一个错误代号,如果有的话
errorInfo - 从语句中返回一个包含错误信息的数组,如果有的话
execute - 执行一条预处理语句
fetch - 从结果集中取出一行
fetchAll - 从结构集中取出一个包含了所有行的数组
fetchColumn - 返回结果集中某一列中的数据
getAttribute - 返回一个 PDOStatement 属性
getColumnMeta - 返回结果集中某一列的结构(metadata?)
nextRowset - 返回下一结果集
rowCount - 返回SQL语句执行后影响的行数
setAttribute - 设置一个PDOStatement属性
setFetchMode - 为 PDOStatement 设定获取数据的方式
三、PDOException
返回PDO触发的错误。你不能从你的代码中抛出一个PDOException异常。//PDOException类:
class PDOException extends Exception
{
// 对应 PDO::errorInfo()
// 或 PDOStatement::errorInfo()
public $errorInfo = null;
// 文本化的错误信息
// 使用Exception::getMessage() 获取它
protected $message;
// SQLSTATE 错误代号
// 使用Exception::getCode() 获取它
protected $code;
}
以上因为用到setAttribute()方法,放上那两个参数,把字段名强制转换成大写。下面列出多有PDO::setAttribute()的参数:
PDO::ATTR_CASE: 强制列名变成一种格式,详细如下(第二个参数):
PDO::CASE_LOWER: 强制列名是小写.
PDO::CASE_NATURAL: 列名按照原始的方式
PDO::CASE_UPPER: 强制列名为大写.
PDO::ATTR_ERRMODE: 错误提示.
PDO::ERRMODE_SILENT: 不显示错误信息,只显示错误码.
PDO::ERRMODE_WARNING: 显示警告错误.
PDO::ERRMODE_EXCEPTION: 抛出异常.
PDO::ATTR_ORACLE_NULLS (不仅仅是ORACLE有效,别的数据库也有效): )指定数据库返回的NULL值在php中对应的数值。
PDO::NULL_NATURAL: 不变.
PDO::NULL_EMPTY_STRING: Empty string is converted to NULL.
PDO::NULL_TO_STRING: NULL is converted to an empty string.
PDO::ATTR_STRINGIFY_FETCHES: Convert numeric values to strings when fetching. Requires bool.
PDO::ATTR_STATEMENT_CLASS: Set user-suppliedstatement class derived from PDOStatement. Cannot be used withpersistent PDO instances. Requires array(string classname, array(mixedconstructor_args)).
PDO::ATTR_AUTOCOMMIT (available in OCI, Firebird and MySQL): Whether to autocommit every single statement.
PDO::MYSQL_ATTR_USE_BUFFERED_QUERY (available in MySQL): Use buffered queries.
例子中的$rs->setFetchMode(PDO::FETCH_ASSOC);是PDOStatement::setFetchMode(),对返回类型的声明。
有如下:
PDO::FETCH_ASSOC -- 关联数组形式
PDO::FETCH_NUM -- 数字索引数组形式
PDO::FETCH_BOTH -- 两者数组形式都有,这是缺省的
PDO::FETCH_OBJ -- 按照对象的形式,类似于以前的 mysql_fetch_object()
查询操作主要是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中包含三个预定义的类,它们分别是PDO、PDOStatement和PDOException
- PDO中包含三个预定义的类,它们分别是PDO、PDOStatement、PDOException
- PDO中包含三个预定义的类,它们分别是PDO、PDOStatement和PDOException
- PDO中包含三个预定义的类--PDO、PDOStatement和PDOException
- 定义一个接口 MediaPlayer,表示家庭影院的一个设备。MediaPlayer 中 包含 play(),stop(), open()三个方法,分别表示播放、停止和开仓功能。
- 题目:名为商品库的数据库中包含有商品规格表Content和商品特性表Property,它们的定义分别为: Content(Code Char(10),Class Char(8),Price F
- pdo的三个预定义类,PDO PDOStatement PDOException
- 2.2 分别定义int,short类型的变量各一个,并依次输出它们的存储空间大小
- 2.3 分别定义float,double类型的变量各一个,并依次输出它们的存储空间大小
- 2.4 分别定义bool,char类型的变量各一个,并依次输出它们的存储空间大小
- 定义一个int型的一维数组,包含10个元素,分别赋值为1~10, 然后将数组中的元素都向前移一个位置,
- 使用DTD文档对 xml 1 作业中的xml文档进行约束,其中河北省只能依次包含石家庄市、张家口市、保定市这三个市,保定市可以有多个或者1个,给保定市定义属性编号为ID类型,必须有;属性name为字符
- Connection、PreparedStatement、Statement、ResultSet是JDBC编程常用的接口,请分别简述它们的作用?
- 定义一个int型的一维数组,包含40个元素,用来存储每个学员的成绩,循环产生40个 0~100之间的随机整数,将它们存储到一维数组中,
- 定义一个int型数组,包含10个元素,分别赋值为1~10, 然后将数组中的元素都向前移一个位置,最后一个元素的值是原来第一个元素的值,然后输出这个数组
- 、写出xml schema与xml dtd文件相比较的优点。 2、完成一个xml schema文件定义,定义一个根元素水果,水果标签中包含苹果、梨、西瓜三个元素,三个元素均为字符类型。
- 如果你有一台电脑,电脑有三个盘分别为D:、E:、F:盘,请你为它们规划一个信息资源管理目录(IRM)。
- @classmethod, @staticmethod和@property这三个装饰器的使用对象是在类中定义的函数。下面的例子展示了它们的用法和行为:
- App Thinning功能中其实有三个独立的机制,分别是App Slicing、on-demand resources以及Bitcode,它们在节省iOS应用资源方面发挥着各自的作用。 iOS 9的
- 定义一个int型的一维数组,包含10个元素,分别赋一些随机整数,然后求出所有元素的最大值,最小值,平均值,和值,并输出出来。