对PHP PDO的一些认识小结

 更新时间:2015年01月23日 09:38:53   投稿:junjie  
这篇文章主要介绍了对PHP PDO的一些认识小结,本文讲解了什么是PDO、启用PDO的配置方法、PDO的预定义类、事务处理例子等内容,需要的朋友可以参考下

1、PDO(PHP Data Object)扩展为PHP定义了一个访问数据库的轻量、持久的接口。实现PDO接口的每一种数据库驱动都能以正则扩展的形式把各自的特色表现出来。

主要:PDO扩展只是一个抽象的接口层,利用PDO扩展本身并不能实现任何数据库操作,必须使用一个特定的数据库PDO驱动访问数据库

2、启动PDO方法:找到php.ini文件将

复制代码 代码如下:

  ;extension=php_pdo.dll

前的分号去掉即可(linux环境下类似)

3、PDO预定义类:

  PDO包含了三个预定义类:PDO、PDOStatement、PDOException

  (1)PDO类:代表一个PHP和数据库之间的连接

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

    beginTransaction:开始事务

    commit:提交事务

    errorCode:从数据库返回一个错误代号,如果有的话

    errorInfo:从数据库返回一个含有错误信息的数组,如果有的话

    exec:执行一条SQL语句并返回影响的行数

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

    lastInsertId:返回最新插入到数据库的行(ID)

    prepare:为执行准备一条SQL语句,返回语句执行后的联合结果集

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

    rollBack:回滚一个事务

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

  (2)PDOStatement类:代表一条预处理语句以及语句执行后的联合结果集

    bindColomn:绑定一个PHP变量到结果集输出列

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

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

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

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

    errorCode:从语句中返回一个错误代号,如果有的话

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

    execute:执行一条预处理语句

    fetch:从结果集中取出一行

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

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

    getAttribute:返回一个PDOStatement属性

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

    nextRowset:返回下一个结果集

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

    setAttribute:设置一个PDOStatement属性

    setFetchMode:为PDOStatement设定获取数据

 

给一个事务处理的简单例子:

复制代码 代码如下:

<?php
    /*
        事务处理
        MYSQL 表引擎  MyISAM  InnoDB
        添加字段 alter table user add money int not null default 0;
        查看表引擎 show create table user
        修改表引擎 alter table user engine=InnoDB
    */
 
     
    try{
        //实例化PDO
        $pdo=new PDO("mysql:host=localhost;dbname=photo","root","123456"。array('3'=>'2'));
    }catch(PDOException $e){
        echo $e->getMessage();
    }
    //设置字符集
    $sql="set name utf8";
    $pdo->exec($sql);
    //开启事务处理
    $pdo->beginTransaction();
    $num=250;
    $sql="update user set money=money-{$num} where id =1";
    $rows=$pdo->exec($sql);
     
    $sql="update user set monet=money-{$num} where id=2";
    $rows+=$pdo->exec($sql);
    //结束事务处理
    if($rows==2){
        $pdo->commit();
    }else{
        $pdo->rollBack();
    }
?>

(事务的主要特性:原子性、一致性、独立性和持久性)

4、PDO最大的特点是引入了参数绑定和预编译

  预编译负责两件事,转移和软解析提速。程序要支持预编译,除了数据库支持外,还需要驱动支持(PDO和NySQLi支持)

5、PDO的效率问题

  (1)在一个大表大数据量中进行测试,PDO的CRUD效率比MySql直连低5%~15%,并且方差大于MySQL直连

  (2)至于负载方面,PDO开启长连接后负载高于MySQL且比较稳定。

其实在实际应用中,90%的程序是不会进行数据库迁移的,有数据库迁移的应用程序少之又少。

相关文章

  • Eclipse PHPEclipse 配置的具体步骤

    Eclipse PHPEclipse 配置的具体步骤

    下面小编就为大家带来一篇Eclipse PHPEclipse 配置的具体步骤。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-08-08
  • PHP使用NuSOAP调用Web服务的方法

    PHP使用NuSOAP调用Web服务的方法

    这篇文章主要介绍了PHP使用NuSOAP调用Web服务的方法,涉及php实现web服务的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-07-07
  • 浅析PHP的ASCII码转换类

    浅析PHP的ASCII码转换类

    本篇文章是对PHP的ASCII码转换类进行了详细的分析介绍,需要的朋友参考下
    2013-07-07
  • php 操作数组(合并,拆分,追加,查找,删除等)

    php 操作数组(合并,拆分,追加,查找,删除等)

    这篇文章主要介绍了php自带的一些操作数组的函数,特整理下方便大家使用
    2012-07-07
  • php代码书写习惯优化小结

    php代码书写习惯优化小结

    本篇文章是对php代码书写习惯优化进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 通过php动态传数据到highcharts

    通过php动态传数据到highcharts

    本文主要介绍了通过php动态传数据到highcharts的相关知识。具有很好的参考价值。下面跟着小编一起来看下吧
    2017-04-04
  • php获取文件名后缀常用方法小结

    php获取文件名后缀常用方法小结

    这篇文章主要介绍了php获取文件名后缀常用方法,实例分析了五种常用的php获取文件名后缀的技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-02-02
  • PHP中curl三种Post请求数据的方式小结

    PHP中curl三种Post请求数据的方式小结

    这篇文章主要给大家介绍了关于PHP中curl三种Post请求数据的方式,在PHP开发的过程中经常需要发送POST请求,POST相比GET要安全很多,而且传输的数据量也较大,需要的朋友可以参考下
    2023-09-09
  • 通过php添加xml文档内容的方法

    通过php添加xml文档内容的方法

    这篇文章主要介绍了通过php添加xml文档内容的方法,涉及appendchild的使用技巧,需要的朋友可以参考下
    2015-01-01
  • PHP学习之数组的定义和填充

    PHP学习之数组的定义和填充

    先了解一下数组,数组就是把一组数据按顺序放在一起。PHP的数组和其它的语言数组有一点点不同:第一,保存的数据是可以是任何类型的;第二,数组的索引可以是数字,也可以是字符串。
    2011-04-04

最新评论