对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%的程序是不会进行数据库迁移的,有数据库迁移的应用程序少之又少。

时间: 2024-10-12 19:05:52

对PDO的认识的相关文章

运用PDO存储将图片、音频文件存入数据库

在数据库中创建表格的时候,有一个字段为image,用来保存图片,那么其类型就是blob,关于blob,百度百科是这样描述的 BLOB (binary large object),二进制大对象,是一个可以存储二进制文件的容器. 在计算机中,BLOB常常是数据库中用来存储二进制文件的字段类型. BLOB是一个大文件,典型的BLOB是一张图片或一个声音文件,由于它们的尺寸,必须使用特殊的方式来处理(例如:上传.下载或者存放到一个数据库). 根据Eric Raymond的说法,处理BLOB的主要思想就是

数据库的事务处理---PDO实现

事务处理用一句简单的术语称为"原子操作",即一件事情,要么全部完成,要么一个也别完成:有一种一荣俱荣,一损俱损的感觉. 最常用的就是在交易过程中,比如在网络中,甲方付费给乙方,钱确认付款,但是乙方并未确认收款,那么,甲方的账户并不会减少,乙方的账户也并不会增加. 只有当甲方确认付款,乙方确认收款,两个步骤都完成,并且不出现错误的时候,双方的账户才会改变 看代码也许更好理解 1 <?php 2 try{ 3 $pdo=new PDO("mysql:host=localho

PHP面向对象之php数据对象(PDO)——图书查看管理

首先创建相关的有关的数据库:数据库的名字我用的是books表名用的是book(下面是完整的数据库,里面的img/img01.jpg是显示的图片的路径) CREATE DATABASE books DEFAULT CHARSET=utf8;USE books; CREATE TABLE book( b_id INT PRIMARY KEY AUTO_INCREMENT, b_name VARCHAR(100) NOT NULL UNIQUE, b_img VARCHAR(50) NOT NULL,

PHP中PDO的配置与说明

住[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+

PHP中MySQL、MySQLi和PDO的用法和区别【原创】

对于一个初学PHP的自己,对数据库的连接有着很大的疑惑,从Java转到PHP.数据库连接变了,以前只知道JDBC连接数据库,或者直接用框架调用,对于的PHP的数据库连接方式,及其应用.不是很了解,于是查阅了很多资料及自己实际操作,写下自己的一点总结笔记. PHP的MySQL扩展(优缺点) 设计开发允许PHP应用与MySQL数据库交互的早期扩展.mysql扩展提供了一个面向过程 的接口: 并且是针对MySQL4.1.3或更早版本设计的.因此,这个扩展虽然可以与MySQL4.1.3或更新的数 : 据

PHP:PDO prepare预处理

许多成熟的数据库都支持预处理语句(Prepared Statements)的概念.它们是什么东西?你可以把它们想成是一种编译过的要执行的SQL语句模板,可以使用不同的变量参数定制它.预处理语句具有两个主要的优点: 查询只需要被解析(或准备)一次,但可以使用相同或不同的参数执行多次.当查询准备好(Prepared)之后,数据库就会分析,编译并优化它要执行查询的计划.对于复杂查询来说,如果你要重复执行许多次有不同参数的但结构相同的查询,这个过程会占用大量的时间,使得你的应用变慢.通过使用一个预处理语

PDO知识点总结

面向对象:object 最先翻译为物质 简称oop 构造函数是对象被创建时自动调用的方法,用来完成类初始化的工作 构造函数可以接受参数,能够在创建对象时赋值给对象属性构造函数可以调用类方法或其他函数构造函数可以调用其他类的构造函数 构造方法在面向对象中,函数被称为方法1 特殊的名称:__construct 2 在实例化对象时,自动被调用3 在内存中划分了对应的内存空间区域 4 构造方法可以像普通方法一样,接收参数:这里的参数通常是用来初始化类中的属性5 构造方法不能重复定义,每个类当中有且只能有

pdo简介--错误与错误处理

PDO 简介——错误和错误处理 标签: database数据库exception脚本phpup 2008-09-28 19:42 1623人阅读 评论(0) 举报  分类: PHP(10)  为适合你的应用开发,PDO 提供了3中不同的错误处理策略. PDO::ERRMODE_SILENT 这是默认使用的模式.PDO会在statement和database对象上设定简单的错误代号,你可以使用PDO->errorCode() 和 PDO->errorInfo() 方法检查错误:如果错误是在对st

PDO

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-

封装PDO

<?php //纯php,可以删掉html代码直接写 //封装类,这样用起来方便,不必每次都去再写了 //用驼峰法命名类名,首字母大写 class ChaXun { public $host="localhost";//数据库地址,可以直接赋值为"localhost" public $uid="root";//数据库用户名,用户名默认为root,可直接赋值为root public $pwd="";//用户密码,自己设置了