PHP和Mysql事物处理
这几天做支付的时候,又用到了事物,为了方便自己以后查看,今天闲的没事就把以前的东西整理下。(其中引用别人的东西,在这里谢谢他们贡献的代码!)
一、事务处理概述:
事务:是若干事件的集合
事务处理:当所有事件执行成功,事务才执行;若有任何一个事件不能成功执行,事务的其它事件也不被执行。
只要你的MySQL版本支持BDB或InnoDB表类型,那么你的MySQL就具有事务处理的能力。这里面,又以InnoDB表类型用的最多,下面就以InnoDB表类型为例简单说一下MySQL中的事务处理。
二、MYSQL的事务处理主要有两种方法。
1、用begin,rollback,commit来实现
begin 开始一个事务
rollback 事务回滚
commit 事务确认
2、直接用set来改变mysql的自动提交模式
MYSQL默认是自动提交的,也就是你提交一个QUERY,它就直接执行!我们可以通过
set autocommit=0 禁止自动提交
set autocommit=1 开启自动提交
———————————————————————————————————————————————————————————————————————————————
PHP中的PDO的事物:(这里我只是整理了下,引用的原文地址:http://www.poluoluo.com/jzxy/201410/315255.html)
- try{
- $pdo=new PDO("mysql:host=localhost;dbname=psp","root","");
- $pdo->exec("set names utf8");
- $pdo->setAttribute(PDO::ATTR_ERRMODE,PDO::ERRMODE_EXCEPTION);//设置异常处理模式
- $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,0);//关闭自动提交
- }catch(PDOException $e){
- echo "数据库连接失败";
- exit;
- }
- try{
- $age=10;
- $pdo->beginTransaction();//开始事务
- $affected_rows1=$pdo->exec("update kfry set k_age=k_age+{$age} where k_name='user1'");
- $affected_rows2=$pdo->exec("update kfry set k_age=k_age-{$age} where k_name='user2'");//随意更改使之执行成功或失败
- /* if($affected_rows1&&$affected_rows2)
- {
- $pdo->commit();
- echo "操作成功";
- }else{
- $pdo->rollback();
- } */
- if(!$affected_rows1)
- throw new PDOException("加入错误");
- if(!$affected_rows2)
- throw new PDOException("减少错误");
- echo "操作成功";
- $pdo->commit();//如果执行到此处前面两个更新sql语句执行成功,整个事务执行成功
- }catch(PDOException $e){
- echo "操作失败:".$e->getMessage();
- $pdo->rollback();//执行事务中的语句出了问题,整个事务全部撤销
- }
- $pdo->setAttribute(PDO::ATTR_AUTOCOMMIT,1);
Mysql中的事物:(自己整理别人的,原文地址:https://my.oschina.net/u/162418/blog/314498)
- <?php
- //数据库连接
- $conn = mysql_connect('localhost', 'root', '');
- mysql_select_db('test', $conn);
- mysql_query("SET NAMES GBK");
- /*
- 支持事务的表必须是InnoDB类型
- 一段事务中只能出现一次:
- mysql_query('START TRANSACTION');//开始事务
- mysql_query(' ROLLBACK ');//回滚事务
- mysql_query('COMMIT');//提交事务
- 如果一段事务中出现多次回滚事务,则在,提交事务时只将第一次回滚前至开始事务后对数据库的所有操作取消,第一次回滚后至提交事务前所有对数据库操作仍将有效,所以一般将回滚语句仅放在提交事务语句前
- 如果一段事务无提交语句,则从开始事务时以下的所有对数据库操作虽执行(执行方法返回对错),但对数据库无影响,但是在执行下段开始事务语句时,前段事务自动提交
- */
- mysql_query('START TRANSACTION');
- $isBad = 0;
- $ins_testTable1 = "INSERT INTO testtable1(NAME,age)VALUES('first',23)";
- if(!mysql_query($ins_testTable1)){
- $isBad =1;
- }
- //插入语句字段名有错
- $ins_testTable2 = "INSERT INTO testtable1(NAME,ages)VALUES('second','24')";
- if(!mysql_query($ins_testTable2)){
- $isBad =1;
- }
- if($isBad == 1){
- echo $isBad;
- mysql_query('ROLLBACK ');
- }
- mysql_query('COMMIT');
- mysql_close($conn);
- ?>
PHP和Mysql事物处理的更多相关文章
- mysql事物处理
mysql事物主要用于处理操作量大,复杂度高的数据.比如说,在人员管理系统中,你删除一个人员,你既要删除人员的基本资料,也要删除和该人员相关的信息,如信箱,文章等.这样,这些数据库操作语句就构成一个事 ...
- MySQL事物机制具备四点:简称ACID操作
MySQL事物机制具备四点:简称ACID操作 1.原子性:要么都做,要么都不做(两条数据(写入和存储)一步未成功,整体回滚) 2.一致性:数据库的状态改变(两条数据(写入和存储)均成功,符合原子性,但 ...
- php与mysql事物处理
PHP与MYSQL事务处理 mysql事物特性 (原子性,一致性,隔离性,持久性) /*MYSQL的事务处理主要有两种方法.1.用begin,rollback,commit来实现begin 开始一个事 ...
- MySQL事物原理及事务隔离级别
mysql事物 事务是访问数据库的一个操作序列,数据库应用系统通过事务集来完成对数据库的存取.事务的正确执行使得数据库从一种状态转换为另一种状态. 事务必须服从ISO/IEC所制定的ACID原则.AC ...
- mysql事物
一. 什么是事务 事务就是一段sql 语句的批处理,但是这个批处理是一个atom(原子) ,不可分割,要么都执行,要么回滚(rollback)都不执行. 二.为什么出现这种技术 为什么要使用事务这个技 ...
- tp 5.0 mysql 事物
mysql 默认 MyISAM存储引擎,不支持事物处理,InnoDB存储引擎提供了具有提交.回滚和崩溃恢复能力的事务安全.但是对比Myisam的存储引擎,InnoDB写的处理效率差一些并且会占用更多 ...
- MySQL事物(一)事务隔离级别和事物并发冲突
数据库的操作通常为写和读,就是所说的CRUD:增加(Create).读取(Read).更新(Update)和删除(Delete).事务就是一件完整要做的事情.事务是恢复和并发控制的基本单位.事务必须始 ...
- MySQL事物系列:3:innodb_flush_log_at_trx_commit小实验
1:创建表和存储过程 mysql> create database trx; Query OK, 1 row affected (0.02 sec) mysql> USE trx Data ...
- MySQL事物系列:2:事物的实现
1:事物的隔离性由锁来实现.事物的持久性和事物的原子性通过redo log来实现.事物的一致性通过undo log来实现. redo log恢复提交事物修改的页操作 undo log回滚到行记录某个特 ...
随机推荐
- Asp.net core 学习笔记 ( OData )
2018-12-10 更新 : 从前我都是把 entity 直接用于 odata 曝露 api 给程序用. 如果这个程序是我们自己写的前端,这样的方式非常好,因为就好比前端可以直接对数据库每一个表做操 ...
- https 学习笔记
参考 : http://www.cnblogs.com/JimmyZhang/archive/2008/10/02/Cryptograph.html https://blog.csdn.net/Jog ...
- Python全栈开发-Day12-Mysql数据库和ORM
本节内容 数据库介绍 mysql 数据库安装使用 mysql管理 mysql 数据类型 常用mysql命令 创建数据库 外键 增删改查表 权限 事务 索引 python 操作mysql ORM sql ...
- Linux 各种软件的安装-Jenkins和svn结合
通常情况下,修改代码,打包,上传,发布,这么个顺序发布程序. 有了Jenkins这些重复性的操作可以统统交给程序自动处理.甚至可以指定发布的时机,例如提交一次svn就自动发布,每天定时发布等. 1:安 ...
- hadoop 企业应用案例--大众点评
hadoop 企业应用案例--大众点评 http://f.dataguru.cn/thread-260531-1-1.html
- 以CapsNet为例谈深度学习源码阅读
本文的参考的github工程链接:https://github.com/laubonghaudoi/CapsNet_guide_PyTorch 之前是看过一些深度学习的代码,但是没有养成良好的阅读规范 ...
- 21. Merge Two Sorted Lists (Java 合并有序链表 空间复杂度O(1))
题目: Merge two sorted linked lists and return it as a new list. The new list should be made by splici ...
- https请求排错过程
1. 看请求有没有到nginx 此时需要查看nginx的日志.一般每一个项目都会配置一个nginx站点,而一个站点都会又一个nginx配置文件,这个文件位于哪里呢?不出意外应该在:下面,如果找不到的话 ...
- 堆排序 GPLT L2-012 关于堆的判断
题目链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805064676261888 分析:这题看起来非常唬人,其实不难 ...
- 【基础知识】【1】CDN
正文: CDN:Content Delivery Network,内容分发网络.使用户访问离ta最近的资源服务器,优化访问速度 优点: 1,内容可以共享,不同站点的同一文件可以不用多次缓存 2,增加下 ...