浅析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 相关文章推荐
PHP 5.0对象模型深度探索之绑定
Sep 05 PHP
php控制linux服务器常用功能 关机 重启 开新站点等
Sep 05 PHP
phpmyadmin提示The mbstring extension is missing的解决方法
Dec 17 PHP
PHP中实现获取IP和地理位置类分享
Feb 10 PHP
php模拟post提交数据的方法
Feb 12 PHP
Adnroid 微信内置浏览器清除缓存
Jul 11 PHP
详解PHP数据压缩、加解密(pack, unpack)
Dec 17 PHP
PHP实现的迪科斯彻(Dijkstra)最短路径算法实例
Sep 16 PHP
如何直接访问php实例对象中的private属性详解
Oct 12 PHP
PHP实现支持CURL字符串证书传输的方法
Mar 23 PHP
laravel config文件配置全局变量的例子
Oct 13 PHP
Git命令之分支详解
Mar 02 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
PHP 和 XML: 使用expat函数(二)
2006/10/09 PHP
php 多个submit提交表单 处理方法
2009/07/07 PHP
php empty() 检查一个变量是否为空
2011/11/10 PHP
PHP使用redis消息队列发布微博的方法示例
2017/06/22 PHP
PHP实现的mysql主从数据库状态检测功能示例
2017/07/20 PHP
PHP删除数组中指定下标的元素方法
2018/02/03 PHP
判断多个元素(RADIO,CHECKBOX等)是否被选择的原理说明
2009/02/18 Javascript
JQuery 前台切换网站的样式实现
2009/06/22 Javascript
Javascript中string转date示例代码
2013/11/01 Javascript
JS计算网页停留时间代码
2014/04/28 Javascript
学习JavaScript设计模式之享元模式
2016/01/18 Javascript
Bootstrap表格和栅格分页实例详解
2016/05/20 Javascript
很棒的js选项卡切换效果
2016/07/15 Javascript
Bootstrap基本样式学习笔记之按钮(4)
2016/12/07 Javascript
Angular2学习教程之组件中的DOM操作详解
2017/05/28 Javascript
ES6扩展运算符的用途实例详解
2017/08/20 Javascript
Vue框架里使用Swiper的方法示例
2018/09/20 Javascript
Vue路由守卫之路由独享守卫
2019/09/25 Javascript
vue 解决遍历对象显示的顺序不对问题
2019/11/07 Javascript
vue.js+ElementUI实现进度条提示密码强度效果
2020/01/18 Javascript
[01:10]DOTA2亚洲邀请赛 征战号角响彻全场
2015/01/06 DOTA
编写Python脚本来实现最简单的FTP下载的教程
2015/05/04 Python
Python常用库推荐
2016/12/04 Python
python 内置函数filter
2017/06/01 Python
django中的setting最佳配置小结
2017/11/21 Python
Python2.7下安装Scrapy框架步骤教程
2017/12/22 Python
一款纯css3实现的竖形二级导航的实例教程
2014/12/11 HTML / CSS
CSS3效果:自定义“W”形运行轨迹实例
2017/03/29 HTML / CSS
商场消防管理制度
2014/01/12 职场文书
中国梦口号
2014/06/13 职场文书
小学数学国培研修日志
2015/11/13 职场文书
2016年学校党支部创先争优活动总结
2016/04/05 职场文书
承诺书的内容有哪些,怎么写?
2019/06/21 职场文书
MongoDB安装使用并实现Python操作数据库
2021/06/28 MongoDB
zabbix自定义监控nginx状态实现过程
2021/11/01 Servers
SSM项目使用拦截器实现登录验证功能
2022/01/22 Java/Android