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

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

<?php
/**php+Mysqli利用事务处理转账问题实例
 * author http://www.lai18.com
 * date 2015-04-19
 * version 1
 **/
  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+Mysqli利用事务处理转账问题实例
http://www.lai18.com/content/368652.html

时间: 2024-10-29 19:06:04

php+Mysqli利用事务处理转账问题实例的相关文章

MYsqli 绑定插入与查询实例

<?php $conn = new mysqli('localhost','root','','orders'); //连接 $prepare = "insert into t100 values (?,?,?)";//预设插入sql $bind = $conn->prepare($prepare); $t1 = NULL; $t2 = 'Www'; $t3 = date('Y-m-d H:i:s'); $bind->bind_param('iss',$t1,$t2,

mysql事务处理用法与实例详解

MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关1.MyISAM:不支持事务,用于只读程序提高性能 2.InnoDB:支持ACID事务.行级锁.并发 3.Berkeley DB:支持事务 一个事务是一个连续的一组数据库操作,就好像它是一个单一的工作单元进行.换言之,永远不会是完整的事务,除非该组内的每个单独的操作是成功的.如果在事务的任何操作失败,则整个事务将失败. 实际上,会俱乐部许多SQL查询到一个组中,将执行所有的人都一起作为事务的一部分. 事务的特性: 事务有以下四

[转]mysql事务处理用法与实例详解

转自:http://www.cnblogs.com/ymy124/p/3718439.html MySQL的事务支持不是绑定在MySQL服务器本身,而是与存储引擎相关1.MyISAM:不支持事务,用于只读程序提高性能 2.InnoDB:支持ACID事务.行级锁.并发 3.Berkeley DB:支持事务 一个事务是一个连续的一组数据库操作,就好像它是一个单一的工作单元进行.换言之,永远不会是完整的事务,除非该组内的每个单独的操作是成功的.如果在事务的任何操作失败,则整个事务将失败. 实际上,会俱

Apache漏洞利用与安全加固实例分析

Apache 作为Web应用的载体,一旦出现安全问题,那么运行在其上的Web应用的安全也无法得到保障,所以,研究Apache的漏洞与安全性非常有意义.本文将结合实例来谈谈针对Apache的漏洞利用和安全加固措施. Apache HTTP Server(以下简称Apache)是Apache软件基金会的一个开放源码的网页服务器,可以在大多数计算机操作系统中运行,是最流行的Web服务器软件之一.虽然近年来Nginx和Lighttpd等Web Server的市场份额增长得很快,但Apache仍然是这个领

PHP MYSQLI中事务处理

MYSQL事务处理让所有sql语句执行成功后才去处理,如果有一条没有成功或者报错就会回滚事务,防止敏感操作处理失败.MYSQL中只有INNODB和BDB类型的数据表才能支持事务处理!其它类型是不支持的! $mysqli->autocommit(FALSE); //关闭自动提交功能 $sql = "UPDATE users SET money = money-300 WHERE username = 'Mike'"; $res1 = $mysqli->query($sql);

利用Mutext实现单实例程序

/// <summary> /// 使用可指示调用线程是否应具有互斥体的初始所有权以及字符串是否为互斥体的名称的 Boolean 值和当线程返回时可指示调用线程是否已赋予互斥体的初始所有权的 Boolean 值初始化 <see cref="T:System.Threading.Mutex"/> 类的新实例. /// </summary> /// <param name="initiallyOwned">如果为 true

利用反射动态创建实例并调用方法

在.Net 中,程序集(Assembly)中保存了元数据(MetaData)信息,因此就可以通过分析元数据来获取程序集中的内容,比如类,方法,属性等,这大大方便了在运行时去动态创建实例. 主要用途: 动态加载DLL,实现插件机制. 实例化DLL中的类型. 执行后期绑定,访问在运行时创建的类型的方法. 首先,新建一个空白解决方案:DllSolution 向解决方案中添加一个类库:RefDll,这将是需要被动态创建的程序集 重命名默认新建的Class1类:Student,这个类将是需要动态创建的类.

Zabbix利用JMX监控多实例Tomcat运行状态

自使用Zabbix监控系统以来,一直想用JMX来监控Tomcat,但是一直都没配置成功,总有一些问题,监控端的报错又很抽象,搜索网上大都是复制粘贴之产物,或者是缺斤短两之网文,但是一直都没放弃,至今终于配置成功,并且成功获取数据,形成图形,现在把自己解决问题的过程和配置的一些心得整理成文. 环境介绍: Centos 6.5 Zabbix 2.2.15 Tomcat 7.0.68 监控JMX配置步骤 1.在zabbix服务器上安装配置zabbix-java-gateway,并且配置相关参数. 2.

mysqli预处理和事务处理

1 应用环境 mysqli预处理功能(大量数据处理时使用) 2 步骤 a)mysqli连接数据库 $mysqli = new mysqli('localhost','root','root','chuanzhi'); b)设置编码 $mysqli->set_charset('gb2312'); c)发送query语句 使用$mysqli->prepare($query)这个方法表示是预处理,如果涉及到取值,必须指定查询字段 $query = "select id,proName,pr