PDO--PHP Data Objects

PDO的环境配置:开启支持PDO 在php.ini配置文件里开启:
	extension=php_pdo.dll
	extension=php_pdo_mysql.dll

	在PDO操作中涉及到类:PDO、PDOStatement(预处理对象)、PDOException(异常类)

一、 PDO类的构造方法:
---------------------------------------------------------
  PDO __construct( string dsn
		[, string username
		[, string password
		[, array driver_options]]] );
 当中:dsn数据库连接信息如“mysql:host=localhost;dbname=库名”
	  dsn的格式:”驱动名:host=主机名;dbname=库名“
      username:用户名
      password:密码
      driver_options:配置选项:
      如: PDO::ATTR_PERSISTENT=>true,是否开启持久链接
	   *PDO::ATTR_ERRMODE=>错误处理模式:(能够是下面三个)(3)
		PDO::ERRMODE_SILENT:不报错误(忽略)(0)
		PDO::ERRMODE_WARNING:以警告的方式报错(1)
		*PDO::ERRMODE_EXCEPTION:以异常的方式报错(推荐使用)。(2)

$pdo =  new PDO("mysql:host=localhost;dbname=lamp36db","root","root");
$pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
其它方法:
--------------------------------------------------------
1. query($sql); 用于运行查询SQL语句。返回PDOStatement对象
2. exec($sql);  用于运行增、删、改操作,返回影响行数;
3. getAttribute(); 获取一个"数据库连接对象"属性。
4. setAttribute(); 设置一个"数据库连接对象"属性。
5. beginTransaction 开启一个事物(做一个回滚点)
6. commit	提交事务
7. rollBack	事务回滚操作。
8. errorCode	获取错误码
9. errorInfo	获取错误信息
10.lastInsertId  获取刚刚加入的主键值。
11.prepare	创建SQL的预处理,返回PDOStatement对象
12.quote	为sql字串加入单引號。

预处理对象PDOStatement对象:
=============================================
我们能够通过PDO的方法来获取PDOStatement:
 1.PDO的query(查询sql)方法获取,用于解析结果集
 2.PDO的prepare(SQL)方法获取,用于处理參数式sql并运行操作。

PDOstatement对象的方法:
----------------------------------------------------------------
1、fetch() 返回结果集的下一行,结果指针下移,到头返回false 。
  	參数: 	PDO::FETCH_BOTH (default)、:索引加关联数组模式
	       	PDO::FETCH_ASSOC、	   :关联数组模式
 	       	PDO::FETCH_NUM、		   :索引数组模式
			PDO::FETCH_OBJ、		   :对象模式
			PDO::FETCH_LAZY		   :全部模式(SQL语句和对象)

2、fetchAll() 通过一次调用返回全部结果,结果是以数组形式保存
      	參数:PDO::FETCH_BOTH (default)、
		PDO::FETCH_ASSOC、
		PDO::FETCH_NUM、
		PDO::FETCH_OBJ、
		PDO::FETCH_COLUMN表示取指定某一列,
		如:$rslist = $stmt->fetchAll(PDO::FETCH_COLUMN,2);取第三列
3、execute() 	负责运行一个准备好了的预处理语句
4. fetchColumn()返回结果集中下一行某个列的值
5. setFetchMode()设置须要结果集合的类型
6. rowCount()  	返回使用增、删、改、查操作语句后受影响的行总数
7. setAttribute()为一个预处理语句设置属性
8. getAttribute()获取一个声明的属性
9. errorCode() 	获取错误码
10. errorInfo() 获取错误信息
11. bindParam() 将參数绑定到对应的查询占位符上
    bool PDOStatement::bindParam ( mixed $parameter , mixed &$variable [, int $data_type [, int $length [, mixed $driver_options ]]] ) 当中: $parameter:占位符名或索引偏移量 &$variable:參数的值,须要按引用传递也就是必须放一个变量
    当中參数:$data_type:数据类型PDO::PARAM_BOOL/PDO::PARAM_NULL/PDO::PARAM_INT/PDO::PARAM_STR/
  	 				  PDO::PARAM_LOB/PDO::PARAM_STMT/PDO::PARAM_INPUT_OUTPUT
         $length:指数据类型的长度 $driver_options:驱动选项。
12. bindColumn() 用来匹配列名和一个指定的变量名,这样每次获取各行记录时,会自己主动将对应的值赋给变量。
13. bindValue() 将一值绑定到对应的一个參数中
14. nextRowset() 检查下一行集
15. columnCount() 在结果集中返回列的数目
16. getColumnMeta() 在结果集中返回某一列的属性信息
17. closeCursor() 关闭游标,使该声明再次运行

在PDO中參数式的SQL语句有两种(预处理sql):
   1.insert into stu(id,name) value(?,?);	//?号式(适合參数少的)
   2.insert into stu(id,name) value(:id,:name);		// 别名式(适合參数多的)
在PDO中为參数式SQL语句赋值有三种:
   1.使用数组
	 $stmt->execute(array("lamp1404","qq2"));
 	 $stmt->execute(array("id"=>"lamp1404","name"=>"qq2"));
   2.用法单个赋值
	 $stmt->bindValue(1,"lamp1901");
	 $stmt->bindValue(2,"qq2");
	 $stmt->execute();

	 $stmt->bindValue(":id","lamp1901",PDO::PARAM_STR);	 //带指定类型
	 $stmt->bindValue(":name","qq2",PDO::PARAM_STR);
	 $stmt->execute();

   3. 用法绑定变量
	 $stmt->bindParam(":id",$id);
	 $stmt->bindParam(":name",$name);
	 $id="lamp1401";
	 $name="qq2";
     $stmt->execute();

事务处理
-----------------------------------------------
	事务:将多条sql操作(增删改)作为一个操作单元,要么都成功,要么都失败。(假设一次插入多条数据,一条运行失败,数据回滚,全部删除)-----

4.  PDO对事务的支持
		第一:被操作的表必须是innoDB类型的表(支持事务)
			MySQL经常使用的表类型:MyISAM(非事务)增删改速度快、InnodB(事务型)安全性高
			//更改表的类型为innoDB类型
			mysql> alter table stu engine=innodb;
				Query OK, 29 rows affected (0.34 sec)
				Records: 29  Duplicates: 0  Warnings: 0
			//查看表结构
			mysql> show create table stu\G;   

		第二:使用PDO就能够操作数据库了
				使用到了PDO中的方法:
					beginTransaction 开启一个事物(做一个回滚点)
					commit		提交事务
					rollBack	事务回滚操作。 

		使用情况:当做多条sql语句处理时(增删改),要求是都必须成功。

PDO--PHP Data Objects,布布扣,bubuko.com

时间: 2024-10-12 17:03:44

PDO--PHP Data Objects的相关文章

使用EF6.0出现:CS0029 无法将类型“System.Data.Entity.Core.Objects.ObjectContext”隐式转换为“System.Data.Objects.ObjectContext”错误

这是因为EF6.0重构了一些命名空间后,和VS原有的实体数据模型模板不一致了(ObjectContext context = ((IObjectContextAdapter)dataContext).ObjectContext;),只要把命名空间改一下就可以了,如下: 把using System.Data.Objects;改成using System.Data.Entity.Core.Objects;即可.

在vs2010使用EF出现CS0012: 类型“System.Data.Objects.DataClasses.EntityObject”在未被引用的程序集中定义

网上查了一通都是在web.config中配置 System.Data.Entity, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089” 无效 解决方案到  C:\Program Files (x86)\Reference Assemblies\Microsoft\Framework\.NETFramework\v4.0 目录拷贝一份System.Data.Entity.dll 到网站bin 目录就好了 编译错误

类型“System.Data.Objects.DataClasses.EntityObject”在未被引用的程序集中定义。

说明: 在编译向该请求提供服务所需资源的过程中出现错误.请检查下列特定错误详细信息并适当地修改源代码. 编译器错误消息: CS0012: 类型“System.Data.Objects.DataClasses.EntityObject”在未被引用的程序集中定义.必须添加对程序集“System.Data.Entity, Version=4.0.0.0, Culture=neutral,  PublicKeyToken=b77a5c561934e089”的引用. 出现这个错误的原因是Web.confi

php之PDO (PHP DATA OBJECT)

从 PHP 5.1 开始附带了 PDO,PHP 数据对象 (PDO) 扩展为PHP访问数据库定义了一个轻量级的一致接口.PDO 提供了一个 数据访问 抽象层,这意味着,不管使用哪种数据库(比如mysql,oracle,mssql-),都可以用相同的函数(方法)来查询和获取数据. 1.创建PDO对象 使用PDO扩展必须在php.ini文件中打开相应的扩展,下图打开了pdo_mysql的扩展: 那怎么创建一个pdo对象呢? <?php //$dsn = "mysql:host=服务器地址/名称

7.19 PDO(php data object-php数据对象)数据库抽象层

<?php header("Content-type: text/html; charset=utf-8"); //PDO操作mysql /*$pdo =new PDO("mysql:host=localhost;dbname=ceshi","root",""); $pdo->exec("set names utf8");//exec()用来执行增删改和设置的语句 $sql = "se

rdo(remote data objects) repo openstack icehouse

problem making ssl connection Error: Cannot retrieve repository metadata (repomd.xml) for repository: openstac                                                                                        k-icehouse. Please verify its path and try again htt

不存在从对象类型 System.Data.Objects.ObjectParameter 到已知的托管提供程序本机类型的映射

在使用EF的时候  试着直接使用T-SQL 有这样的实现ObjectContext.ExecuteStoreQuery 其中有个构造函数ObjectContext.ExecuteStoreQuery(string s,parm object[] p) 网上全是这种写法 se.ExecuteStoreQuery<Departments>("SELECT dId, dName, dManager FROM Departments where [email protected]"

从具体化“System.Data.Objects.MaterializedDataRecord”类型到“XXXX”类型的指定强制转换无效。

在EF里面使用CreateQueryl的时候出现异常 这是原来有问题的代码 se.CreateQuery<Departments>("SELECT Departments.dId, Departments.dName, Departments.dManager FROM Departments") .ToList().ForEach(w => { System.Console.WriteLine(w.dId + " " + w.dName + &q

PHP学习笔记A

//语法错误(syntax error)在语法分析阶段,源代码并未被执行,故不会有任何输出. /* [命名规则] */常量名 类常量建议全大写,单词间用下划线分隔 // MIN_WIDTH变量名建议用下划线方式分隔 // $var_name函数名建议用驼峰命名法 // varName定界符建议全大写 // <<<DING, <<<'DING'文件名建议全小写和下划线.数字 // func_name.php私有属性名.方法名建议加下划线 // private $_name