mysqli扩展库---事务控制
1, 有一张银行账号表
create table account(
id int primary key,
balance float
);
2,现在有一段php程序,要完成把1号10元钱,转到2号账号上
<?php
$mysqli = new MySQLi("127.0.0.1","root","123456","test");
if($mysqli->connect_error){
die("连接错误".$mysqli->connect_error);
}
$sql1 = "update account set balance = balance -2 where id = 1";
$sql2 ="update account set balance2 = balance + 2 where id = 2";
$b1 = $mysqli->query($sql1) or die($mysqli->error);
$b2 = $mysqli->query($sql2) or die($mysqli->error);
if(!$b1 || !$b2){
echo "失败!";
}else{
echo "成功!";
}
$mysqli->close();
从上面代码可知,如果$sql1此时需要一种方法来控制两个sql操作同时成功,同时失败。
3,事务用于保证数据的一致性,它由一组相关的dml语句组成,该组的dml语句要么全部成功,要么全部失败。如:网上转账就是典型的要用事务来处理,用以保证数据的一致性。
<?php
$mysqli = new MySQLi("127.0.0.1","root","123456","test");
if($mysqli->connect_error){
die("连接错误".$mysqli->connect_error);
}
//将提交设为false,【事务一旦提交就没有机会回滚】
$mysqli->autocommit(false);
//设定保存点1
$sql1 = "update account set balance = balance -2 where id = 1";
$sql2 ="update account set balance2 = balance + 2 where id = 2";
$b1 = $mysqli->query($sql1); //每次执行query时候,会设定保存点,此处设定保存点2
$b2 = $mysqli->query($sql2); //此处设定保存点3 if(!$b1 || !$b2){
echo "失败!".$mysqli->error;
$mysqli->rollback(); //如果失败,回滚到保存点1
}else{
echo "成功!";
$mysqli->commit(); //一旦提交,没有机会回滚
}
$mysqli->close();
4,在mysql控制台可以使用事务来操作,具体步骤如下:
① 开启一个事务,start transaction。
② 做保存点,如果不做,在开启事务时候,默认做一个保存点。savepoint 保存点名称。
③ sql操作。
④ 可以回滚,可以提交。如果没有问题就提交commit;如果觉得有问题就回滚,rollback to 某个保存点;一旦提交,就没法回滚。
5,事务的四大特点acid
① 原子性(Atomicity),原子性是指事务是一个不可分割的工作单位,事务中的操作要么都发生,要么都不发生。
② 一致性(Consistency),事务必须使数据库从一个一致性状态变换到另外一个一致性状态。
③ 隔离性(IsoIation),事务的隔离性是多个用户并发访问数据库时,数据库为每一个用户开启的事务,不能被其他事务的操作数据所干扰,多个并发事务之间要相互隔离。
④ 持久性(Durability),持久性是指一个事务一旦被提交,它对数据库中数据的改变就是永久性的,接下来即使数据库发生故障也不应该对其有任何影响。
mysqli扩展库---事务控制的更多相关文章
- php数据库编程---mysqli扩展库
1,mysqli扩展库允许我们访问MySQL数据库,并对MySql数据库进行curd操作.Mysqli扩展库比mysql扩展库加强了. 2,mysqli扩展库和mysql扩展库的比较 (1) mysq ...
- PHP使用mysqli扩展库实现增删改查(面向对象版)
mysqli扩展库是mysql扩展库的改进版本,在mysql扩展库的基础上提高了稳定性和效率,mysqli扩展库有两套东西,一套就是面向过程的mysqli另一套是面向对象的mysqli.操作方式大体和 ...
- mysqli扩展库操作mysql数据库
配置环境 配置php.ini文件让php支持mysqli扩展库 extension=php_mysqli.dll 建库建表 详见博客 “mysql扩展库操作mysql数据库” 查询数据库 <?p ...
- 【小结】有关mysql扩展库和mysqli扩展库的crud操作封装
现阶段php如果要操作mysql数据库 php给我们提供了3套库 1.mysql扩展库 面向过程操作 2.mysqli扩展库 面向对象操作和面向过程操作并存 安全性和效率高于mysql扩展库 ...
- 使用php的mysqli扩展库操作mysql数据库
简单介绍mysqli: 1.mysqli(mysql improve mysql扩展库的增强版) mysql扩展库和mysqli扩展库的区别 1.mysqli的稳定性 安全性 和 执行效率有所提高 ...
- mysqli扩展库应用---程序范例
通过mysqli扩展库对用户表user1进行增删改查操作,用户表user1结构如下: 1,建立数据库操作类库mysqliTool.class.php,代码如下: <?php class mysq ...
- php mysqli扩展库之预处理操作
分享下php使用mysqli扩展库进行预处理操作的二个例子,有意研究mysqli用法的朋友,可以参考学习下,一定会有所帮助的. 例1.使用mysqli扩展库的预处理技术 mysqli stmt 向数据 ...
- PHP mysqli 扩展库(面向对象/数据库操作封装/事务控制/预编译)
1.和mysql扩展库的区别: (1 安全性.稳定性更高 (2 提供了面向对象和面向过程两种风格 2.php.ini 中的 extension=php_mysqli.dll 解除封印 3.面 ...
- PHP的 Mysqli扩展库的多语句执行
$mysqli->multi_query($sqls); 执行多个sql语句,返回true/false 有结果集时,使用 $mysqli->store_result(); 来获取结 ...
随机推荐
- git远程代码库回滚(webstorm下)
git远程代码库回滚(webstorm下) 1. 场景 添加了一个文件[file-for-test.js]到git的控制下 进行了三次修改,并分别进行了三次commit,最后进行了一次push git ...
- java实现最通俗易懂的01背包问题
这几天一直在想背包问题,昨天还有个学长专门讲了,但是还是不是很理解,今天我终于想通了背包问题,其实只要理解了这个思路,不管用什么语言,肯定是能编出来的.下面我就来介绍一下背包问题. 1.题目描述: 有 ...
- 搭建Spring开发环境并编写第一个Spring小程序
搭建Spring开发环境并编写第一个Spring小程序 2015-05-27 0个评论 来源:茕夜 收藏 我要投稿 一.前面,我写了一篇Spring框架的基础知识文章,里面没 ...
- RabbitMQ EasyNetq 用法
EasyNETQ帮助类 public class MQHelper { /// <summary> /// 发送消息 /// </summary> public static ...
- [C++ Mind Map] class and memory
class and memory
- 23-tcp协议——TIME_WAIT状态和FIN_WAIT2状态
23-tcp协议——TIME_WAIT状态和FIN_WAIT2状态 摘自:https://blog.csdn.net/qq_35733751/article/details/80146161 2018 ...
- 不设置环境变量 直接启动tomcat
window: 设置 startup.bat set JAVA_HOME=C:\Program Files\Java\jdk1.8.0_144set JRE_HOME=C:\Program Files ...
- C# 订单号的生成
/** * 根据当前系统时间加随机序列来生成订单号 * @return 订单号 */ public static string Generat ...
- 自己(转)String、StringBuffer与StringBuilder之间区别
String.StringBuffer与StringBuilder之间区别 最近学习到StringBuffer,心中有好些疑问,搜索了一些关于String,StringBuffer,StringB ...
- 20169202 2016-2017-2《TCP/IP协议攻击》实验总结--十一周
APR缓存中毒(ARP cache poisoning) 实验原理 ARP缓存是ARP协议的重要组成部分.ARP协议运行的目标就是建立MAC地址和IP地址的映射,然后把这一映射关系保存在ARP缓存中, ...