php mysql 事务,用新的PHP插件实现MySQL为基础的事务

用新的PHP插件实现MySQL为基础的事务 - 应用软件 - 电脑教程网

用新的PHP插件实现MySQL为基础的事务

日期:2007-06-28   荐:

  事务处理支持很长时间以来一直是大多数MySQL开发者的心愿,随着MySQL 4.0的发布,这个心愿最后终于得以实现。MySQL 4.0后不久,拥有一个新的MySQL插件的PHP 5.x也发布了。这个新插件,MySQL Improved,使得PHP开发者通过利用本地的PHP函数,获得了这些新的事务处理能力。这篇简短的教程将向你说明怎样利用这些新的MySQLi函数,用PHP实现以MySQL为基础的事务。

  概要

  如果你还不知道,那么我可以告诉你,事务只是一组SQL语句,通常因为它们是彼此相互依赖的,所以要在全有或全无(all-or-nothing)的模式下执行。只有当所有组成的语句都执行成功了,一个事务才算是成功了;任何一个语句中的失败应该都会导致系统“回滚”到它先前的状态,以避免数据连接/崩溃问题。

  对于这一点,两个银行帐户间的转帐是一个很好的例子。在数据库级,这样的转帐包括两个步骤:首先,从源帐户中扣除转帐的金额,然后将其加到目标帐户中。如果在第二步中发生了错误,那么第一步就必须被取消,以避免不相符的情况(和愤怒的客户聚众滋事)。事务安全系统将自动地撤到系统先前的“快照”。

  大多数数据库(包括MySQL)通过一个命令的组合来完成这个:

  * START TRANSACTION命令标志着一个新的事务组的开始。它后面常接一系列的SQL命令。

  * COMMIT命令标志着一个事务组的结束,表示事务期间做的所有改变应该被提交或者使之永久化。

  * ROLLBACK命令标志着一个事务组的结束,表示事务期间所做的所有改变应该被撤消。

  PHP中的事务处理函数

  PHP中的MySQLi插件引进了新的函数,帮助开发者利用MySQL的事务处理能力。实质上,这些函数对等地被叫做SQL START TRANSACTION,COMMIT和 ROLLBACK命令。列表A为你展示了一个例子:

  列表A

  

  // save in array, use to generate form

  $result = mysqli_query($dbh, "SELECT * FROM accounts");

  while ($row = mysqli_fetch_assoc($result)) {

  $accounts[] = $row;

  }

  // close connection

  mysqli_close($dbh);

  ?>

  

  

  


·以假乱真 Linux中实现Vista界面·Max粒子系统轻松实现群蝶飞舞·利用VB6.0实现五线谱作曲工具·轻松实现电脑一分为二:Betwin·用VC实现小型矢量图形系统的开发(上)·盗QQ的密码软件模拟实现(VC)·让Excel 2007实现双面打印的两种另类方·洪水攻击原理及代码实现全攻略·用ATL实现VC插件·ASP.NET系统用户权限设计与实现

   TRANSFER

  

标签: