码迷,mamicode.com
首页 > 其他好文 > 详细

PDO事务处理

时间:2014-09-13 00:40:54      阅读:363      评论:0      收藏:0      [点我收藏+]

标签:style   blog   color   io   使用   ar   for   数据   2014   


PDO事务处理

2014-9-3 10:44:19 By jiancaigege
====================================


概要:将多条sql操作(增删改)作为一个操作单元,要么都成功,要么都失败。
单条数据不用事务处理
被操作的表必须是innoDB类型的表(支持事务)
MySQL常用的表类型:MyISAM(非事务)增删改速度快、InnodB(事务型)安全性高

更改表的类型为innoDB类型
mysql> alter table stu engine=innodb;

使用:
在PDO预处理的基础上添加,如下格式:

 1 try{
 2 
 3 $m->beginTransaction();//开启事务处理
 4 
 5 //PDO预处理以及执行语句...
 6 
 7 $m->commit();//提交事务
 8 
 9 }catch(PDOException $e){
10 
11 $m->rollBack();//事务回滚
12 //相关错误处理
13 }

 

示例:

 1 $m = new PDO($dsn,$user,$pwd);
 2 $m->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
 3 try{
 4 $m->beginTransaction();//开启事务处理
 5 
 6 $stmt=$m->prepare("insert into stu(name,sex,age,classid)values(?,?,?,?)");
 7 $data=array(
 8 array("user1",1,22,"lamp76"),
 9 array("user2",1,20,"lamp76"),
10 array("user3",0,22,"lamp76")
11 );
12 foreach($data as $v){
13 $stmt->execute($v);
14 echo $m->lastInsertId();
15 }
16 $m->commit();
17 echo "提交成功!";
18 }catch(PDOException $e){
19 $m->rollBack();//回滚
20 die("提交失败!");
21 }

 

PDO事务处理

标签:style   blog   color   io   使用   ar   for   数据   2014   

原文地址:http://www.cnblogs.com/52fhy/p/3969313.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!