php+Mysqli利用事务处理转账问题实例

5年以前  |  阅读数:233 次  |  编程语言:PHP 

本文实例讲述了php+Mysqli利用事务处理转账问题的方法。分享给大家供大家参考。具体实现方法如下:


    <?php 
      header("Content-type:text/html; charset=utf-8"); 

      $mysqli = new mysqli("localhost", "root", "064319", "php"); 
      $mysqli->set_charset("utf8"); 

      if($mysqli->connect_errno) { 
       die('数据库连接失败'.$mysqli->connect_error); 
      } 

      $mysqli->autocommit(false); //自动提交模式设为false 
      $flag = true; //事务是否成功执行的标志 

      $query = "update account set balance=balance-1000 where id=3"; 
      $result = $mysqli->query($query); 
      $affected_count = $mysqli->affected_rows; 
      if(!result || $affected_count == 0) {  //失败 
       $flag = false;   
      } 

      $query = "update account set balance=balance+1000 where id=2"; 
      $result = $mysqli->query($query); 
      $affected_count = $mysqli->affected_rows; 
      if(!$result || $affected_count == 0) { 
       $flag = false; 
      } 

      if($flag) { 
       $mysqli->commit(); 
       echo '转账成功'; 
      } else { 
       $mysqli->rollback(); 
       echo '转账失败'; 
      } 

      $mysqli->autocommit(true); //重新设置事务为自动提交 
      $mysqli->close(); 
    ?>

希望本文所述对大家的php程序设计有所帮助。

 相关文章:
PHP分页显示制作详细讲解
SSH 登录失败:Host key verification failed
获取IMSI
将二进制数据转为16进制以便显示
获取IMEI
文件下载
贪吃蛇
双位运算符
PHP自定义函数获取搜索引擎来源关键字的方法
Java生成UUID
发送邮件
年的日历图
提取后缀名
在Zeus Web Server中安装PHP语言支持
让你成为最历害的git提交人
Yii2汉字转拼音类的实例代码
再谈PHP中单双引号的区别详解
指定应用ID以获取对应的应用名称
Python 2与Python 3版本和编码的对比
php封装的page分页类完整实例