PHP基础 mysqli的事务处理
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的事务处理的更多相关文章
- php+Mysqli利用事务处理转账问题实例
本文实例讲述了php+Mysqli利用事务处理转账问题的方法.分享给大家供大家参考 <?php /**php+Mysqli利用事务处理转账问题实例 * author http://www.lai ...
- PHP MYSQLI中事务处理
MYSQL事务处理让所有sql语句执行成功后才去处理,如果有一条没有成功或者报错就会回滚事务,防止敏感操作处理失败.MYSQL中只有INNODB和BDB类型的数据表才能支持事务处理!其它类型是不支持的 ...
- php基础-mysqli
基本八个步骤 //连接数据库 $link = mysqli_connect('localhost', 'root', ''); //判断是否连接成功 if (!$link) { exit('数据库连接 ...
- mysqli预处理和事务处理
1 应用环境 mysqli预处理功能(大量数据处理时使用) 2 步骤 a)mysqli连接数据库 $mysqli = new mysqli('localhost','root','root','chu ...
- PHP数据库扩展mysqli的函数试题
1.mysqli链接数据库的方式是什么? 2.mysqli获取链接错误号的属性是什么? 3.mysqli获取链接错误信息的属性是什么? 4.mysqli执行sql语句的函数是什么? 5.mysqli获 ...
- PHP处理MySQL事务代码
php使用mysqli进行事务处理 <?php$db = new mysqli("localhost","root",""," ...
- C# Winform下一个热插拔的MIS/MRP/ERP框架12(数据处理基类)
作为ERP等数据应用程序,数据库的处理是重中之重. 在框架中,我封装了一个数据库的基类,在每个模组启动或窗体启动过程中,实例化一个基类即可调用CRUD操作(create 添加read读取 update ...
- PHP.15-mysqli
从PHP5.0开始可以使用mysql(i), 是一个面向对象的技术(新加功能都会以对象形式添加) i:表示改进,1. 功能增加了, 2,效率大大增加(以后的PHP项目改成mysqli),3,更稳定 m ...
- mysqli事务处理demo
<?php $mysqli=new mysqli("localhost", "root", "123456", "xsph ...
随机推荐
- 用python虚拟串口
在linux下调试串口程序,无奈下面的硬件还没到位,所以,想着自己模拟一个串口用用.试了下下面这段代码: #!/usr/bin/env python #coding=utf-8 import pty ...
- DNS(一)之禁用权威域名服务器递归解析
DNS dns是互联网中最核心的带层级的分布式系统,负责把域名解析成ip,把IP解析出域名,以及宣告邮件路由信息等等,使得使用域名访问网站,收发邮件成了可能. bind(berkeley Intern ...
- centos 搭建git服务器
centos 6搭建git服务器 安装 rpm -ivh http://mirrors.aliyun.com/epel/epel-release-latest-6.noarch.rpm yum ins ...
- NXP Mifare S50标准IC卡- 访问位(Access Bits) 分析
Mifare S50 标准IC卡有1K 字节的EEPROM,主要用来存储数据和控制信息.1K 字节的EEPROM分成16 个区,每区又分成4 段,每1段中有16 个字节.每个区的最后一个段叫“尾部&q ...
- sql自带函数语句
--取数值表达式的绝对值select abs(-41) 41select abs(41) 41select abs(-41.12) 41.12select abs(41.12 ...
- JS字符串转换成json对象。。。。
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- JVM 关闭钩子
1.功能 在jvm中添加关闭钩子(Runtime.getRuntime().addShutdownHook(shutdownHook);)后,当jvm关闭时会执行系统中已经设置的所有通过该方法添加的钩 ...
- Understanding Convolutions
http://colah.github.io/posts/2014-07-Understanding-Convolutions/ Posted on July 13, 2014 neural netw ...
- 快捷键_Mac
苹果Mac系统常用快捷键 Command+Tab 任意情况下切换应用程序 - 向前循环 Shift+Command+Tab 切换应用程序 - 向后循环 Command+L 当前程序是浏览器时,可以直接 ...
- phpstorm webstorm安装主题 sublime样 还有都可以用的注册码
注册码 webstorm phpstorm 基本所有版本通吃 webstrom9.0.3 通过 phpstorm 8.0.1 User Name: EMBRACE License Key: ==== ...