php结合mysql与mysqli扩展处理事务的方法


Posted in PHP onJune 29, 2016

本文实例讲述了php结合mysql与mysqli扩展处理事务的方法。分享给大家供大家参考,具体如下:

以下只是展示如何应用,具体用的时候要加上判断,如果都执行成功则提交,否则回滚

看前先分清mysqli与mysql扩展是不一样的

mysqli扩展处理事物:

$mysqli=new mysqli('localhost','root','123456','test');
$mysqli->autocommit(false);//开始事物
$query="update a set money=money+30 where a_id='1'";
$mysqli->query($query);
$query="update b set money=money-30 where b_id='1'";
$mysqli->query($query);
//$mysqli->rollback();//回滚
$mysqli->commit();   //提交事物
$mysqli->autocommit(true);//不使用事物

mysql扩展处理事物:

<?php
mysql_connect('localhost','root','123456');
mysql_select_db('test');
mysql_query('SET AUTOCOMMIT=0'); //不自动提交
mysql_query('BEGIN');       //开始事务
$query="UPDATE a SET money = money +30 WHERE a_id =1";
mysql_query($query);
$query="UPDATE b SET money = money -30 WHERE b_id =1";
mysql_query($query);
mysql_query('COMMIT');       //提交
//mysql_query('ROLLBACK');     //回滚
mysql_query('SET AUTOCOMMIT=1'); //打开自动提交
?>

对mysql扩展处理事务的说明,原文可参考本站:

MYSQL的事务处理主要有两种方法。

1、用begin,rollback,commit来实现

begin 开始一个事务
rollback 事务回滚
commit    事务确认

2、直接用set来改变mysql的自动提交模式

MYSQL默认是自动提交的,也就是你提交一个QUERY,它就直接执行!我们可以通过:

set autocommit=0  禁止自动提交
set autocommit=1 开启自动提交

来实现事务的处理。

但注意当你用 set autocommit=0 的时候,你以后所有的SQL都将做为事务处理,直到你用commit确认或rollback结束,注意当你结束这个事务的同时也开启了个新的事务!按第一种方法只将当前的作为一个事务!

个人推荐使用第一种方法!

MYSQL中只有INNODB和BDB类型的数据表才能支持事务处理!其他的类型是不支持的!(切记!)

希望本文所述对大家PHP程序设计有所帮助。

PHP 相关文章推荐
PHP number_format() 函数定义和用法
Jun 01 PHP
php中{}大括号是什么意思
Dec 01 PHP
PHP管理依赖(dependency)关系工具 Composer的自动加载(autoload)
Aug 18 PHP
PHP类的反射用法实例
Nov 03 PHP
PHP文件读写操作相关函数总结
Nov 18 PHP
php微信公众开发之获取周边酒店信息的方法
Dec 22 PHP
php搜索文件程序分享
Oct 30 PHP
基于php(Thinkphp)+jquery 实现ajax多选反选不选删除数据功能
Feb 24 PHP
详解PHP处理字符串类似indexof的方法函数
Jun 11 PHP
PHP根据树的前序遍历和中序遍历构造树并输出后序遍历的方法
Nov 10 PHP
PHP折半(二分)查找算法实例分析
May 12 PHP
如何在PHP环境中使用ProtoBuf数据格式
Jun 19 PHP
php简单解析mysqli查询结果的方法(2种方法)
Jun 29 #PHP
php mysqli查询语句返回值类型实例分析
Jun 29 #PHP
thinkphp框架实现数据添加和显示功能
Jun 29 #PHP
thinkphp框架实现删除和批量删除
Jun 29 #PHP
浅谈PHP值mysql操作类
Jun 29 #PHP
验证token、回复图文\文本、推送消息的实用微信类php代码
Jun 28 #PHP
php 在字符串指定位置插入新字符的简单实现
Jun 28 #PHP
You might like
PHP调用Webservice实例代码
2011/07/29 PHP
获取PHP警告错误信息的解决方法
2013/06/03 PHP
php结合curl实现多线程抓取
2015/07/09 PHP
十个PHP高级应用技巧果断收藏
2015/09/25 PHP
yii2 数据库读写分离配置示例
2017/02/10 PHP
PHP实现RSA签名生成订单功能【支付宝示例】
2017/06/06 PHP
php文件上传原理与实现方法详解
2019/12/20 PHP
Javascript load Page,load css,load js实现代码
2010/03/31 Javascript
javascript插入样式实现代码
2012/02/22 Javascript
web的各种前端打印方法之jquery打印插件PrintArea实现网页打印
2013/01/09 Javascript
JsRender实用入门教程
2014/10/31 Javascript
JavaScript插件化开发教程(六)
2015/02/01 Javascript
JavaScript实现拖拽网页内元素的方法
2015/04/15 Javascript
ECMAScript6函数默认参数
2015/06/12 Javascript
jQuery切换所有复选框选中状态的方法
2015/07/02 Javascript
js中javascript:void(0) 真正含义
2020/11/05 Javascript
整理Javascript数组学习笔记
2015/11/29 Javascript
详解JavaScript逻辑And运算符
2015/12/04 Javascript
尝试动手制作javascript放大镜效果
2015/12/25 Javascript
使用jQuery处理AJAX请求的基础学习教程
2016/05/10 Javascript
浅谈jQuery操作类数组的工具方法
2016/12/23 Javascript
Bootstrap 下拉多选框插件Bootstrap Multiselect
2017/01/22 Javascript
如何解决vue与传统jquery插件冲突
2017/03/20 Javascript
用node撸一个监测复联4开售短信提醒的实现代码
2019/04/10 Javascript
springboot+vue实现文件上传下载
2020/11/17 Vue.js
初步解析Python下的多进程编程
2015/04/28 Python
Python复制文件操作实例详解
2015/11/10 Python
Python数据结构与算法之图的广度优先与深度优先搜索算法示例
2017/12/14 Python
python excel转换csv代码实例
2019/08/26 Python
对python中list的五种查找方法说明
2020/07/13 Python
Unix/Linux开发面试题
2016/08/16 面试题
房地产推广策划方案
2014/05/19 职场文书
公司授权委托书格式范文
2014/10/02 职场文书
个人作风纪律整顿整改措施
2014/10/25 职场文书
2014年环卫工作总结
2014/11/22 职场文书
房地产置业顾问工作总结
2015/10/23 职场文书