PDO事务处理

简介:

PDO事务处理

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


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

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

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

try{

$m->beginTransaction();//开启事务处理

//PDO预处理以及执行语句...

$m->commit();//提交事务

}catch(PDOException $e){

$m->rollBack();//事务回滚
//相关错误处理
}

 

示例:

$m = new PDO($dsn,$user,$pwd);
$m->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);
try{
$m->beginTransaction();//开启事务处理

$stmt=$m->prepare("insert into stu(name,sex,age,classid)values(?,?,?,?)");
$data=array(
array("user1",1,22,"lamp76"),
array("user2",1,20,"lamp76"),
array("user3",0,22,"lamp76")
);
foreach($data as $v){
$stmt->execute($v);
echo $m->lastInsertId();
}
$m->commit();
echo "提交成功!";
}catch(PDOException $e){
$m->rollBack();//回滚
die("提交失败!");
}

目录
相关文章
|
6月前
|
SQL 关系型数据库 MySQL
MySQL操作之事务管理
MySQL操作之事务管理
29 0
|
9月前
|
存储 SQL Oracle
八、MySQL之事务控制语言
八、MySQL之事务控制语言
74 0
|
9月前
|
SQL 关系型数据库 MySQL
MySQL事务管理(二)
MySQL事务管理
63 0
|
9月前
|
SQL 存储 关系型数据库
MySQL事务管理(一)
MySQL事务管理
76 0
|
9月前
|
存储 SQL 关系型数据库
MySQL事务管理(三)
MySQL事务管理
68 0
|
10月前
|
SQL 存储 关系型数据库
MySQL 数据库操作
MySQL 数据库操作
|
缓存 关系型数据库 MySQL
Mysql事务&隔离级别解读和分析
Mysql事务&隔离级别解读和分析
|
SQL 关系型数据库 MySQL
MySQL DDL数据库操作
全称Structured Query Language,结构化查询语言。操作关系型数据库的编程语言,定义了一套操作关系型数据库统一标准。
101 0
|
SQL 物联网 Shell
SQLite 事务处理 | 学习笔记
快速学习 SQLite 事务处理
164 0
|
关系型数据库 MySQL Java
mysql事务特性-隔离级别
mysql事务特性-隔离级别
81 0