1: <?php

   2: //                PHP 的mysqli的事务处理

   3: //========================================================

   4: //执行多条sql语句,如果都成功则提交事务,如果一个执行失败则回滚事务

   5: //把多条sql语句的执行看成一个sql语句,要么都成功,要么都失败

   6: //例:银行转账

   7: //mysql4.0以上版本都启用了事务

   8: //但目前只有InnoDB和BDB两种表类型支持事务,

   9: //在命令行中:默认创建的表类型为MyISAM表类型,是不支持事务的

  10: //在命令行中建表时添加 type=InnoDB ,默认自动提交事务autocommit,不能回滚

  11: //手动提交:

  12: //1.关闭自动提交 set autocommit=0;

  13: //2.开启事务 start transaction (mysqli中不需要开启,自动开启)

  14: //3.$mysqli->query($sql); 执行sql

  15: //4.判断执行是否成功

  16: //5.如果都成功,则提交事务commit(),否则回滚事务 rollback()

  17:  

  18: //创建连接对象

  19: $mysqli = new mysqli("localhost","root","1234","BankDB");

  20:  

  21: if($error=$mysqli->connect_error){

  22:     die("连接数据库失败:".$error);

  23: }

  24:  

  25: //设置传输字符编码

  26: $mysqli->query('set names utf8');

  27: // 或者

  28: // $mysqli->set_charset("uf8");

  29:  

  30: //关闭自动提交事务

  31: $mysqli->autocommit(false);

  32:  

  33: $error=true;

  34:  

  35: $price=50;

  36:  

  37: $sql1= "update uinfo set umoney=umoney-{$price} where uname='张三';";

  38: $sql2= "update uinfo set umoney=umoney+{$price} where uname='李四';";

  39:  

  40: //执行sql语句

  41: $result1 = $mysqli->query($sql1);

  42: if(!$result1) {

  43:     $error=false;

  44:     echo "从张三转出失败!\n";

  45: }

  46: else if($mysqli->affected_rows==0)

  47: {

  48:     $error=false;

  49:     echo "张三的钱没有变化!\n";

  50: }

  51:  

  52: //执行sql语句

  53: $result2 = $mysqli->query($sql2);

  54: if(!$result2){

  55:     $error=false;

  56:     echo "转入李四失败\n";

  57: } 

  58: else if($mysqli->affected_rows==0)

  59: {

  60:     $error=false;

  61:     echo "李四的钱没有变化!\n";

  62: }

  63:  

  64: //判断执行过程是否出错,如果语句都执行成功则提交事务,否则回滚事务

  65: if ($error) {

  66:     $mysqli->commit();

  67:     echo "事务提交,转账成功!";

  68: } else {

  69:     $mysqli->rollback();

  70:     echo "事务回滚,转账失败!";

  71: }

  72:  

  73: //打开自动提交事务

  74: $mysqli->autocommit(true);

  75:  

  76: $mysqli->close();

  77: ?>

PHP基础 mysqli的事务处理的更多相关文章

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

    本文实例讲述了php+Mysqli利用事务处理转账问题的方法.分享给大家供大家参考 <?php /**php+Mysqli利用事务处理转账问题实例 * author http://www.lai ...

  2. PHP MYSQLI中事务处理

    MYSQL事务处理让所有sql语句执行成功后才去处理,如果有一条没有成功或者报错就会回滚事务,防止敏感操作处理失败.MYSQL中只有INNODB和BDB类型的数据表才能支持事务处理!其它类型是不支持的 ...

  3. php基础-mysqli

    基本八个步骤 //连接数据库 $link = mysqli_connect('localhost', 'root', ''); //判断是否连接成功 if (!$link) { exit('数据库连接 ...

  4. mysqli预处理和事务处理

    1 应用环境 mysqli预处理功能(大量数据处理时使用) 2 步骤 a)mysqli连接数据库 $mysqli = new mysqli('localhost','root','root','chu ...

  5. PHP数据库扩展mysqli的函数试题

    1.mysqli链接数据库的方式是什么? 2.mysqli获取链接错误号的属性是什么? 3.mysqli获取链接错误信息的属性是什么? 4.mysqli执行sql语句的函数是什么? 5.mysqli获 ...

  6. PHP处理MySQL事务代码

    php使用mysqli进行事务处理 <?php$db = new mysqli("localhost","root",""," ...

  7. C# Winform下一个热插拔的MIS/MRP/ERP框架12(数据处理基类)

    作为ERP等数据应用程序,数据库的处理是重中之重. 在框架中,我封装了一个数据库的基类,在每个模组启动或窗体启动过程中,实例化一个基类即可调用CRUD操作(create 添加read读取 update ...

  8. PHP.15-mysqli

    从PHP5.0开始可以使用mysql(i), 是一个面向对象的技术(新加功能都会以对象形式添加) i:表示改进,1. 功能增加了, 2,效率大大增加(以后的PHP项目改成mysqli),3,更稳定 m ...

  9. mysqli事务处理demo

    <?php  $mysqli=new mysqli("localhost", "root", "123456", "xsph ...

随机推荐

  1. Alpha版本十天冲刺——Day 3

    站立式会议 会议总结 队员 今天完成 遇到的问题 明天要做 感想 鲍亮 Android端登录验证接口 子线程无法返回从服务器获取的信息. 注册接口.忘记密码接口 开发经验不足,有一个问题不知道怎么解决 ...

  2. 整理CSS引发的相关理论的梳理

    写在前面 因为原先项目中的CSS样式乱得不行,所以领导决定要花大时间整理一下样式,也为了后续维护起来方便.其实也苦了自己,想想也是一件多烦的事情,烦的原因并非是说这件事情做起来没有意义,而是觉得这样的 ...

  3. Wavefront OBJ 转换成OpenGL ES使用的C/C++文件

    项目需要展示3D max模型,通过调研

  4. java编程思想-java集合总结-基本概念

    1.java 容器类类库的用途是"保存对象",并将其划分为两个不同的概念: 1)Collection.一个独立元素的序列,这些元素都服从一条或多条规则.List 必须按照插入的顺序 ...

  5. Android项目结构 以及体系结构

    学习Android平台的人一般对Android的平台的应该有点认识 其它的就不多讲了 Android项目一般由以下几个部分构成 以上是一个简单的Android项目结构目录图 1. src  主要是 源 ...

  6. CentOS配置163的yum源

    entOS系统自带的更新源的速度在国内非常慢,在国内为了让CentOS6使用速度较快快的YUM更新源,建议选择163(网易)的更新源. 1.下载repo文件wget http://mirrors.16 ...

  7. Java排序算法——表插入排序

    //================================================= // File Name : ListInsertSort_demo //----------- ...

  8. 关于软件工程结对编程作业 PairProject : Elevator Scheduler(电梯调度算法的实现与测试)的总结

    1)结对编程队友 1106xxxx 张扬 1106xxxx 杨军 其中,此项目的编程实现主要由前者完成. 2)关于结对编程 结对编程的优点: 最直接的一点:在结对编程中,由于有另一个人在你身边和你配合 ...

  9. 云服务程序在启动的时候执行Powershell脚本

    如果在云服务程序启动时候,需要执行Powershell脚本,我们需要将脚本嵌入到程序中,并且编写一个cmd来执行这个脚本,具体如下: 1.编写测试的Powershell脚本:每隔10分钟 检测dns ...

  10. HTTP2.0介绍

    HTTP2.0的所有通信都是在一个TCP连接上完成的. 1.信息传输术语 1.1 流 虚拟信道,可以承载双向消息,每个流都有一个唯一的整数标识符(1.2....N); 1.2 消息 逻辑上的HTTP消 ...