在PDO操作数据库的方法中,今天我们要学事务处理,举个例子说,小明要给小红跟小兰转账,
在这里我们需要实现三件事情
1,小明余额-10
2,小红余额+5
3,小兰余额+5
这三件操作要么同时实现,要么同时失败,那么什么能解决这个问题呢?这就要考虑到我们的事务处理了
PDO处理事务一共有三个属性:
① 原子性(Atomic)(Atomicity)
事务必须是原子工作单元;对于其数据修改,要么全都执行,要么全都不执行。通常,与某个事务关联的操作具有共同的目标,并且是相互依赖的。如果系统只执行这些操作的一个子集,则可能会破坏事务的总体目标。原子性消除了系统处理操作子集的可能性。
② 一致性(Consistent)(Consistency)
事务在完成时,必须使所有的数据都保持一致状态。在相关数据库中,所有规则都必须应用于事务的修改,以保持所有数据的完整性。事务结束时,所有的内部数 据结构(如 B 树索引或双向链表)都必须是正确的。某些维护一致性的责任由应用程序开发人员承担,他们必须确保应用程序已强制所有已知的完整性约束。例如,当开发用于转 帐的应用程序时,应避免在转帐过程中任意移动小数点。
③ 隔离性(Insulation)(Isolation)
由并发事务所作的修 改必须与任何其它并发事务所作的修改隔离。事务查看数据时数据所处的状态,要么是另一并发事务修改它之前的状态,要么是另一事务修改它之后的状态,事务不 会查看中间状态的数据。这称为隔离性,因为它能够重新装载起始数据,并且重播一系列事务,以使数据结束时的状态与原始事务执行的状态相同。当事务可序列化 时将获得最高的隔离级别。在此级别上,从一组可并行执行的事务获得的结果与通过连续运行每个事务所获得的结果相同。由于高度隔离会限制可并行执行的事务 数,所以一些应用程序降低隔离级别以换取更大的吞吐量。
④ 持久性(Duration)(Durability)
事务完成之后,它对于系统的影响是永久性的。该修改即使出现致命的系统故障也将一直保持。
处理数据重要分为三部
1. 开启事物:beginTransaction()方法;
2,提交事务:commit()方法;
3,事务回滚:rollback()方法;
下面是小编写了一个具体的转账功能应用到了事务,不懂的地方详见注释
<?php //pdo连接数据库方法 $dsn="mysql:dbname=stucourse;host=127.0.0.1"; //数据库的用户名 $user="root"; //数据库的密码 $password="root"; $object = new PDO($dsn,$user,$password); $hidden=empty($_POST['hidden'])?'':$_POST['hidden']; if(!$hidden) { $sql = "select * from student"; $object->setAttribute(PDO::ATTR_ERRMODE, PDO::CASE_UPPER); $result = $object->query($sql); $result->setFetchMode(PDO::FETCH_ASSOC); $result_array = $result->fetchAll(); //print_r($result_array);exit; }else{ #执行转账 try{ //生成PDO对象(面向对象); $object = new PDO($dsn,$user,$password); $object->beginTransaction(); // 开启一个事务 // $row = null; $sql="update student set stu_balance=stu_balance-10 WHERE stu_name='小王'"; $sql1="update student set stu_balance=stu_balance+5 WHERE stu_name='小明'"; $sql2="update student set stu_balance=stu_balance+5 WHERE stu_name='小张'"; //PDO->exec() — 处理一条SQL语句,并返回所影响的条目数 $result = $object->exec($sql); $result1 = $object->exec($sql1); $result2 = $object->exec($sql2); if(($result+$result1+$result2)==3){ $object->commit();//执行成功-》提交事务 echo "转账成功!"; header( "Location: pdo_rollback.php" ); }else{ $object->rollback(); // 执行失败,事务回滚 throw new PDOException('操作失败'); } }catch(PDOException $e){ die ("Error!: " . $e->getMessage() . "<br/>"); } } ?> <h1>转账功能</h1> <form action="pdo_rollback.php" method="post"> <input type="hidden" value="1" name="hidden"> <table border="1"> <tr> <td>姓名</td> <td>剩余金额</td> </tr> <?php foreach($result_array as $k=>$v){ ?> <tr> <td><?php echo $v['stu_name'] ?></td> <td><?php echo $v['stu_balance'] ?></td> </tr> <?php } ?> <tr> <td colspan="3"><input type="submit" value="执行(金额为10¥)" class="submit"></td> </tr> </table> </form>
有什么不懂得可以留言呦!希望可以帮到你们!!!