浅析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 相关文章推荐
PHP5权威编程阅读学习笔记 附电子书下载
Jul 05 PHP
thinkPHP的Html模板标签使用方法
Nov 13 PHP
php jquery 多文件上传简单实例
Dec 23 PHP
PHP动态生成javascript文件的2个例子
Apr 11 PHP
Yii结合CKEditor实现图片上传功能
Jun 13 PHP
php算法实例分享
Jul 14 PHP
php需登录的文件上传管理系统
Mar 21 PHP
yii实现使用CUploadedFile上传文件的方法
Dec 28 PHP
PHP数组编码gbk与utf8互相转换的两种方法
Sep 01 PHP
实现PHP搜索加分页
Oct 12 PHP
PHP时间处理类操作示例
Sep 05 PHP
Laravel框架实现定时Task Scheduling例子
Oct 22 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
thinkphp 多表 事务详解
2013/06/17 PHP
laravel5.0在linux下解决.htaccess无效和去除index.php的问题
2019/10/16 PHP
基于thinkphp6.0的success、error实现方法
2019/11/05 PHP
关于jquery动态增减控件的一些想法和小插件
2010/08/01 Javascript
JavaScript加强之自定义callback示例
2013/09/21 Javascript
为开发者准备的10款最好的jQuery日历插件
2014/02/04 Javascript
jquery $(document).ready()和window.onload的区别浅析
2015/02/04 Javascript
深入浅出理解javaScript原型链
2015/05/09 Javascript
jquery模拟alert的弹窗插件
2015/07/31 Javascript
jquery实现的蓝色二级导航条效果代码
2015/08/24 Javascript
Vuejs第十二篇之动态组件全面解析
2016/09/09 Javascript
Bootstrap框架的学习教程详解(二)
2016/10/18 Javascript
微信小程序 网络API Websocket详解
2016/11/09 Javascript
JavaScript自动点击链接 防止绕过浏览器访问的方法
2017/01/19 Javascript
nodejs入门教程六:express模块用法示例
2017/04/24 NodeJs
angularjs2中父子组件的数据传递的实例代码
2017/07/05 Javascript
vue iview组件表格 render函数的使用方法详解
2018/03/15 Javascript
js实现图片推拉门效果代码实例
2019/05/18 Javascript
json数据格式常见操作示例
2019/06/13 Javascript
使用pkg打包ThinkJS项目的方法步骤
2019/12/30 Javascript
koa2的中间件功能及应用示例
2020/03/05 Javascript
vc6编写python扩展的方法分享
2014/01/17 Python
使用python实现正则匹配检索远端FTP目录下的文件
2015/03/25 Python
详解利用django中间件django.middleware.csrf.CsrfViewMiddleware防止csrf攻击
2018/10/09 Python
PyCharm鼠标右键不显示Run unittest的解决方法
2018/11/30 Python
Python检测数据类型的方法总结
2019/05/20 Python
Python Pandas 转换unix时间戳方式
2019/12/07 Python
Tensorflow 实现将图像与标签数据转化为tfRecord文件
2020/02/17 Python
HTML5 文件域+FileReader 分段读取文件并上传到服务器
2017/10/23 HTML / CSS
印度低票价航空公司:GoAir
2017/10/11 全球购物
最耐用行李箱,一箱永流传:Briggs & Riley(全球终身保修)
2017/12/07 全球购物
商务英语专业自荐信
2013/10/14 职场文书
2014年语文教研组工作总结
2014/12/06 职场文书
院系推荐意见
2015/06/05 职场文书
导游词之澳门妈祖庙
2019/12/19 职场文书
TypeScript 使用 Tuple Union 声明函数重载
2022/04/07 Javascript