PDO中包含三个预定一类:PDO、PODStatement和PDOException。

1.PDO类

PDO类代表一个PHP和数据库之间的连接,PDO类所拥有的方法如下:

PDO:构造器,构建一个新的PDO对象。

beginTransaction:事务开始。

commit:提交事务

errorCode:从数据库返回一个错误代号。

errorInfo:从数据库返回一个含有错误信息的数据。

exec:执行一条sql语句并还回影响的行数

getAttribute:返回一个数据库连接属性。

lastInsertId:返回最新插入到数据库的行id

prepare:为执行准备一条sql语句,返回语句执行后的联合结果集(PDOStatement)。

query:执行一条sql语句并返回结果集

quote:返回添加引号的字符串,使其可以用于sql中

rollBack:事务回滚

setAttribute:设置一个数据库连接属性

2.PDOStatement类

PDOStatement类代表一条预处理语句以及语句执行后的联合结果集合,拥有的方法:

bindColumn:绑定一个PHP变量到结果集中的输出序列。

bindParam:绑定一个PHP变量到一个预处理语句中的参数

bindValue:绑定一个值到预处理语句中的参数

closeCursor:关闭游标,是语句可以再次执行。

columnCount:返回结果集中的列的数量

errorCode:从语句中返回一个错误的代号

errorInfo:从语句中返回一个包含错误信息的数组

execute:执行一条预处理语句

fetch:从结果集中去除一行

fetchAll:从结果集中取出一个包含所有行的数组

fetchColumn:返回结果集中某一列中的数据。

getAttribute:返回一个PDOStatement属性

getColumnMeta:返回结果集中某一列的结构。

nextRowset:返回下一个结果集

rowCount:返回sql语句执行后影响的行数

setAttribute:设置一个PDOStatement属性

setFetchModel:为PDOStatement设定获取数据的方式。

3.PDOException

PDOException是对exception的简单从写。

使用PDO 案例1:

<?php
try{
$dsn='mysql:host=localhost;dbname=shen';//设置PDO的数据源
$db=new PDO($dsn,'root','rootroot');//构造方法
//设置异常
$db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
$db->exec("set names utf8");
$sql = "insert into a2(name) values('asdf')";
$db->exec($sql);//执行语句
//使用预处理
$insert = $db->prepare('insert into a2(name) values(?)');
$insert->execute(array('王'));
$insert->execute(array('lisi'));
//查询结果
$sql='select name from a2';
$query = $db->prepare($sql);
$query->execute();
var_dump($query->fetchAll(PDO::FETCH_ASSOC)); }catch(PDOException $err){
echo $err->getMessage();
}
?>

案例2:绑定参数和预编译

<?php
try{
$dsn='mysql:host=localhost;dbname=shen';//设置PDO的数据源
$dbh=new PDO($dsn,'root','rootroot');//构造方法
$dbh->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
   $name = '王';
$sth = $dbh->prepare('select name from a2 where name = :name');
$sth->bindparam(':name',$name);
$sth->execute();
var_dump($sth->fetchAll(PDO::FETCH_ASSOC));
$sth = $dbh->prepare('select * from a2 where name = ?');
$sth->bindparam(,$name,PDO::PARAM_STR);
$sth->execute();
var_dump($sth->fetchAll(PDO::FETCH_ASSOC)); }catch(PDOException $err){
echo $err->getMessage();
}
?>

在mysql的应用中,为了防止注入共计,通常使用intval,addslashes等函数对值进行转义,转变成sql中合法的类型,这种方法比较复杂,而使用PDO的bindParam方法就变得比较简单,只需要在函数中指定第三个参数,就可以把值转换为需要的类型并拼接到原先的语句中。

案例3:事务处理

事务一般分为三步

1.开始事务

2.执行事务中需要执行的sql语句

3.提交事务 完成事务。

<?php
try{
$dsn='mysql:host=localhost;dbname=shen';//设置PDO的数据源
$db=new PDO($dsn,'root','rootroot');//构造方法
$db->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
$db->beginTransaction();//开始事务
//开始执行sql语句
$db->commit();//提交事务 结束 }catch(PDOException $err){
echo $err->getMessage();
}
?>

PHP的PDO的更多相关文章

  1. 比Mysqli操作数据库更简便的方式 。PDO

    下面来说一下PDO 先画一张图来了解一下 mysqli是针对mysql这个数据库扩展的一个类 PDO是为了能访问更多数据库 如果出现程序需要访问其他数据库的话就可以用PDO来做 PDO数据访问抽象层1 ...

  2. pdo的使用

    PHP 数据对象 (PDO) 扩展为PHP访问数据库定义了一个轻量级的一致接口. PDO 提供了一个数据访问抽象层,这意味着,不管使用哪种数据库,都可以用相同的函数(方法)来查询和获取数据. PDO随 ...

  3. PHP中PDO事务的使用方法

    事务 (Transaction) 是操作数据库中很重要的一个功能, 它可以让你预定一条, 或者一系列 SQL 语句, 然后一起执行. 在执行的过程中, 如果其中的某条执行失败, 可以回滚所有已更改的操 ...

  4. PDO连接mysql数据库

    1.PDO简介 PDO(PHP Data Object) 是PHP 5 中加入的东西,是PHP 5新加入的一个重大功能,因为在PHP 5以前的php4/php3都是一堆的数据库扩展来跟各个数据库的连接 ...

  5. PDO概念 分析 练习

    PDO 翻译过来叫做数据访问抽象层 它是一个数据访问的层面,实际上是一个类,也就是说所有操作数据库的代码,都是通过这个层面完成的 该图好理解大概就是这样一种模式 现在考虑的是能不能使用同一个类,上层代 ...

  6. PDO

    'PDO'是数据访问抽象层'用mysqli类找到mysqli驱动根据驱动操作mysqli数据库'其他类找到sqlserver驱动根据驱动操作sqlserve数据库'PDO 访问其他数据库 PDO的用法 ...

  7. 前端学PHP之PDO预处理语句

    × 目录 [1]定义 [2]准备语句 [3]绑定参数[4]执行查询[5]获取数据[6]大数据对象 前面的话 本来要把预处理语句和前面的基础操作写成一篇的.但是,由于博客园的限制,可能是因为长度超出,保 ...

  8. 前端学PHP之PDO基础操作

    × 目录 [1]创建PDO [2]使用PDO [3]事务处理 前面的话 PDO(php data object)扩展类库为php访问数据库定义了轻量级的.一致性的接口,它提供了一个数据库访问抽象层,这 ...

  9. CANopen学习——PDO

    查找资料时,发现一个很好的博客,博主剖析的通俗易懂 http://www.cnblogs.com/winshton/p/4897556.html   PDO定义: 过程数据对象,用来传输实时数据.因为 ...

  10. PHP基础之PDO

    简介 PDO(PHP Data Object)是指PHP数据对象,它定义了一个轻量级的一致接口来统一操作各种数据库.PDO提供了一个数据访问抽象层,这意味着,不管使用哪种数据库,都可以用相同的函数(方 ...

随机推荐

  1. requests库基本使用

    在python中,字典的输出内容跟json格式内容一样,但是字典的格式是字典,json的格式是字符串,所以在传输的时候(特别是网页)要转换使用. r.text返回的是Unicode型的数据. r.co ...

  2. Hibernate操作指南-搭建一个简单的示例(基于原生API和XML)

  3. buildroot--uboot&kernel&rootfs全编译工具

    参考: http://www.crifan.com/files/doc/docbook/buildroot_intro/release/html/buildroot_intro.html https: ...

  4. lucence.net+盘古分词

    第一步: 添加盘古和lucence的dll引用 第二步: 拷贝Dict文件夹到项目  demo里面是Dictionaries 不过官方建议改成Dict 然后把所有项右击属性 改为“如果较新则复制” 第 ...

  5. NET基础(3):is 和 as 操作符

    在C#语言中进行类型转换的另外一种方式是使用is和as操作符.is检查对象是否兼容于指定类型,返回Boolean值true或false.注意,is操作符永远不抛出异常,例如以下代码: Object o ...

  6. C#中调用user32.dll库的keybd_Event函数,操作键盘

    keybd_event()的函数原型是: void keybd_event( byte bVk,          //虚拟键码 byte bScan,       //该键的硬件扫描码 dword ...

  7. sort

    sort -n -k2 filename 按第二列,按顺序排列 sort -nr -k2 filename 按第二列,按反向顺序排列

  8. mongodb学习(一)

    操作系统环境:ubuntu. 安装mongodb:apt-get install mongodb 安装后运行:mongod提示:[initandlisten] exception in initAnd ...

  9. jQuery CSS操作及jQuery的盒子模型

    jQuery CSS-jQuery CSS方法 jQuery CSS-jQuery盒子模型

  10. Easy Tag Write(3.2)

    package skyseraph.android.util; /** * @Title : LogUtil.java * @Package : tcl.nfc.phone.util * @Class ...