PDO基础(一)

设置PDO连接属性:

bool PDO::setAttribute(int $attribute,mixed $value);

取得PDO连接属性

mixed PDO::getAttribute(in$attribute);

PDO对象中常用的属性

PDO::ATTR_AUTOCOMMIT 表示是否开启自动提交,一般用于事务处理。取值范围:1(开启),0

PDO::ATTR_CASE  表示控制大小写 取值范围:PDO::CASE_LOWER\PDO::CASE_UPPER\PDO::CASE_NATURAL(原始)

PDO::ATTR_ERRMODE 笔试错误处理方式 取值范围 PDO::ERRORMODE_SILENT:常规错误处理/PDO::ERRORMODE_WARNING:警告处理/PDO::ERRORMODE_EXCEPTION:异常处理

PDO::ATTR_PERSISTENT 表示是否用于长连接  取值范围 true、false

sql语句:

PDO中int PDO::exec(string $sql)

$pdo->exec($sql);//exec()之恩能够执行insert、update、delete这类操作,不能执行带有返回结果的操作。该函数的返回值类型为整型,表示此次操作所影响的行数

query();可以用来执行select操作;返回的是pdostatement类的类对象;

string PDO::lastInsertId(); //取得最后一次插入数据的id值

PDOStatement:处理结果集,实现预处理

相关方法:int PDOStatement::rowCount(void)  //行

int PDOStatement::columnCount(void) //列

 解析结果集(4种方式):

1、 fetch() :正常解析

2、 fetchAll() :一次性从结果集中取得所有数据并放入一个二维数组

3、 fetchColumn() :从结果集中当前行的某一列获取数据

4、 fetchObject() :将结果集当前行的数据存放至指定的类的类对象中

mixed PDOStatement::fetch (int $fetch_style)

int $fetch_style:表示获取数据的方式,它的取值如下:

PDO::FETCH_ASSOC :关联数组

PDO::FETCH_NUM :索引

PDO::FETCH_BOTH  :任意

PDO::FETCH_OBJ :将数组据存入一个对象

PDO::FETCH_BOUND (bindColumn) :将数组存放到绑定的变量

 

array PDOStatement::fetchAll()  //此方法返回的是一个二维数组,结果集有多少航,二维数组就有多少行;

 string PDOStatement::fetchColumn ([ int $column_number = 0 ] )

 mixed PDOStatement::fetchObject ( string $class_name )

可以通过这个函数来获取某一列的值

 

PDO事务简单例子

PDO事务的简单例子:模拟汇款过程,A账户先减,B账户再加,若出错则抛出异常,事务回滚,try catch

 1 <?php
 2 header("content-type:text/html;charset=utf-8");
 3     $host = 'localhost';
 4     $username='root';
 5     $password = '123456';
 6     $dbname = 'xxx';
 7     $dsn = "mysql:host=$host;dbname=$dbname";
 8 
 9     
10     $pdo = new PDO($dsn, $username, $password);
11     //设置字符集
12     $pdo->exec('set names gbk');
13     //开启事务
14     $pdo->beginTransaction();
15     //设置错误
16     $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION );
17     
18     try 
19     {
20         $sql = 'select * from account where id= 1 and cash > 2000';
21         $res = $pdo->query($sql);
22         $i = $res->rowCount();
23         if($i <= 0)
24         {
25             throw new PDOException('您的余额不足哦');
26         }
27         
28         $query = 'update account set cash = cash -2000 where id = 1';
29         $i = $pdo->exec($query);
30         if($i < 1)
31         {
32             throw  new PDOException('取钱失败,请重试');
33         }
34         
35         $query = 'update account set cash = cash + 2000 where id= 2';
36         $i = $pdo->exec($query);
37         if($i < 1)
38         {
39             throw new PDOException('存钱失败,请重试');
40         }
41         $pdo->commit();
42         
43     }
44     catch (PDOException $e)
45     {
46         echo $e->getMessage();
47         $pdo->rollBack();
48     }
49     
50     
51     
52 
53 
54 ?>
posted @ 2012-11-05 23:28  RightDear  阅读(283)  评论(0编辑  收藏  举报