首页 > 代码库 > PDO事务处理
PDO事务处理
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事务处理
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。