浅析Mysql 数据回滚错误的解决方法


Posted in PHP onAugust 05, 2013

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类型的数据表才能支持事务处理!其他的类型是不支持的!
***:一般MYSQL数据库默认的引擎是MyISAM,这种引擎不支持事务!如果要让MYSQL支持事务,可以自己手动修改:

方法如下:
1.修改c:\appserv\mysql\my.ini文件,找到skip-InnoDB,在前面加上#,后保存文件。

2.在运行中输入:services.msc,重启mysql服务。

3.到phpmyadmin中,mysql->show engines;(或执行mysql->show variables like 'have_%'; ),查看InnoDB为YES,即表示数据库支持InnoDB了。
也就说明支持事务transaction了。

4.在创建表时,就可以为Storage Engine选择InnoDB引擎了。如果是以前创建的表,可以使用mysql->alter table table_name type=InnoDB;
或 mysql->alter table table_name engine=InnoDB;来改变数据表的引擎以支持事务。
/*方法一*/

/*************** transaction--1 ***************/
$conn = mysql_connect('localhost','root','root') or die ("数据连接错误!!!");
mysql_select_db('test',$conn);
mysql_query("set names 'GBK'"); //使用GBK中文编码;
//开始一个事务
mysql_query("BEGIN"); //或者mysql_query("START TRANSACTION");
$sql = "INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')";
$sql2 = "INSERT INTO `user` (`did`, `username`, `sex`) VALUES (NULL, 'test1', '0')";//这条我故意写错
$res = mysql_query($sql);
$res1 = mysql_query($sql2);  
if($res && $res1){
mysql_query("COMMIT");
echo '提交成功。';
}else{
mysql_query("ROLLBACK");
echo '数据回滚。';
}
mysql_query("END");

/*方法二*/
/**************** transaction--2 *******************/
mysql_query("SET AUTOCOMMIT=0"); //设置mysql不自动提交,需自行用commit语句提交
$sql = "INSERT INTO `user` (`id`, `username`, `sex`) VALUES (NULL, 'test1', '0')";
$sql2 = "INSERT INTO `user` (`did`, `username`, `sex`) VALUES (NULL, 'test1', '0')";//这条我故意写错
$res = mysql_query($sql);
$res1 = mysql_query($sql2);  
if($res && $res1){
mysql_query("COMMIT");
echo '提交成功。';
}else{
mysql_query("ROLLBACK");
echo '数据回滚。';
}
mysql_query("END"); //事务处理完时别忘记mysql_query("SET AUTOCOMMIT=1");自动提交
PHP 相关文章推荐
PHP4 与 MySQL 数据库操作函数详解
Dec 06 PHP
php 破解防盗链图片函数
Dec 09 PHP
防止MySQL注入或HTML表单滥用的PHP程序
Jan 21 PHP
php自动加载的两种实现方法
Jun 21 PHP
php程序的国际化实现方法(利用gettext)
Aug 14 PHP
通过5个php实例细致说明传值与传引用的区别
Aug 08 PHP
thinkphp框架下404页面设置 仅三步
May 14 PHP
PHP中的使用curl发送请求(GET请求和POST请求)
Feb 08 PHP
thinkPHP5.0框架简单配置作用域的方法
Mar 17 PHP
php把字符串指定字符分割成数组的方法
Mar 12 PHP
php装饰者模式简单应用案例分析
Oct 23 PHP
php5.3/5.4/5.5/5.6/7常见新增特性汇总整理
Feb 27 PHP
解析php mysql 事务处理回滚操作(附实例)
Aug 05 #PHP
php多层数组与对象的转换实例代码
Aug 05 #PHP
注意:php5.4删除了session_unregister函数
Aug 05 #PHP
PHP中fwrite与file_put_contents性能测试代码
Aug 02 #PHP
PHP-Fcgi下PHP的执行时间设置方法
Aug 02 #PHP
基于php中使用excel的简单介绍
Aug 02 #PHP
PHP自动识别字符集并完成转码详解
Aug 02 #PHP
You might like
收音机指标测试方法及仪器
2021/03/01 无线电
is_uploaded_file函数引发的不能上传文件问题
2013/10/29 PHP
PHP四种基本排序算法示例
2015/04/09 PHP
分享五个PHP7性能优化提升技巧
2015/12/07 PHP
php处理带有中文URL的方法
2016/07/11 PHP
Laravel多用户认证系统示例详解
2018/03/13 PHP
Yii2框架视图(View)操作及Layout的使用方法分析
2019/05/27 PHP
PHPExcel实现的读取多工作表操作示例
2020/04/14 PHP
javascript中关于break,continue的特殊用法与介绍
2012/05/24 Javascript
Jquery实现Div上下移动示例
2014/04/23 Javascript
重写document.write实现无阻塞加载js广告(补充)
2014/12/12 Javascript
jQuery中has()方法用法实例
2015/01/06 Javascript
jQuery中offsetParent()方法用法实例
2015/01/19 Javascript
JavaScript实现同一页面内两个表单互相传值的方法
2015/08/12 Javascript
jQuery判断checkbox选中状态
2016/05/12 Javascript
javascript 判断用户有没有操作页面
2017/10/17 Javascript
vue单页应用加百度统计代码(亲测有效)
2018/01/31 Javascript
JavaScript实现一个简易的计算器实例代码
2018/05/10 Javascript
微信小程序页面间值传递的两种方法
2018/11/26 Javascript
vue实现路由懒加载及组件懒加载的方式
2019/06/11 Javascript
layui实现下拉框三级联动
2019/07/26 Javascript
python基于BeautifulSoup实现抓取网页指定内容的方法
2015/07/09 Python
详解Django缓存处理中Vary头部的使用
2015/07/24 Python
Python实现Linux的find命令实例分享
2017/06/04 Python
python爬取Ajax动态加载网页过程解析
2019/09/05 Python
Pyspark读取parquet数据过程解析
2020/03/27 Python
html5借用repeating-linear-gradient实现一把刻度尺(ruler)
2019/09/09 HTML / CSS
欧迪办公美国官网:Office Depot
2016/08/22 全球购物
网络体系结构及协议的定义
2014/03/13 面试题
数控专业大学毕业生职业规划范文
2014/02/06 职场文书
销售内勤岗位职责
2014/04/15 职场文书
工商局领导班子存在的问题整改措施思想汇报
2014/10/05 职场文书
房屋质量投诉书
2015/07/02 职场文书
初中数学课堂教学反思
2016/02/17 职场文书
MySQL 表空间碎片的概念及相关问题解决
2021/05/07 MySQL
疑《守望先锋2》A测截图泄露 或将推出新模式、新界面
2022/04/03 其他游戏