当前位置:  数据库>mysql

MySql事务无法回滚的原因有哪些

    来源: 互联网  发布时间:2014-10-16

    本文导语:  使用MySQL时,如果发现事务无法回滚,但Hibernate、Spring、JDBC等配置又没有明显问题时,不要苦恼,先看看MySQL创建的表有没有问题,即表的类型。 InnoDB和MyISAM是在使用MySQL最常用的两个表类型,各有优缺点,视具体应用而定。...

使用MySQL时,如果发现事务无法回滚,但Hibernate、Spring、JDBC等配置又没有明显问题时,不要苦恼,先看看MySQL创建的表有没有问题,即表的类型。

InnoDB和MyISAM是在使用MySQL最常用的两个表类型,各有优缺点,视具体应用而定。基本的差别为:MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持。MyISAM类型的表强调的是性能,其执行数度比InnoDB类型更快,但是不提供事务支持,而InnoDB提供事务支持已经外部键等高级数据库功能。

MyIASM是IASM表的新版本,有如下扩展:

二进制层次的可移植性。

NULL列索引。

对变长行比ISAM表有更少的碎片。

支持大文件。

更好的索引压缩。

更好的键吗统计分布。

更好和更快的auto_increment处理。

以下是一些细节和具体实现的差别:

1. InnoDB不支持FULLTEXT类型的索引。

2. InnoDB中不保存表的具体行数,也就是说,执行select count(*) from table时,InnoDB要扫描一遍整个表来计算有多少行,但是MyISAM只要简单的读出保存好的行数即可。注意的是,当count(*)语句包含where条件时,两种表的操作是一样的。

3. 对于AUTO_INCREMENT类型的字段,InnoDB中必须包含只有该字段的索引,但是在MyISAM表中,可以和其他字段一起建立联合索引。

4. DELETE FROM table时,InnoDB不会重新建立表,而是一行一行的删除。

5. LOAD TABLE FROM MASTER操作对InnoDB是不起作用的,解决方法是首先把InnoDB表改成MyISAM表,导入数据后再改成InnoDB表,但是对于使用的额外的InnoDB特性(例如外键)的表不适用。

另外,InnoDB表的行锁也不是绝对的,如果在执行一个SQL语句时MySQL不能确定要扫描的范围,InnoDB表同样会锁全表,例如update table set num=1 where name like “%aaa%”

任何一种表都不是万能的,只用恰当的针对业务类型来选择合适的表类型,才能最大的发挥MySQL的性能优势。

在MySQL 5.0里面,MyISAM和InnoDB存储引擎性能差别并不是很大,针对InnoDB来说,影响性能的主要是 innodb_flush_log_at_trx_commit 这个选项,如果设置为1的话,那么每次插入数据的时候都会自动提交,导致性能急剧下降,应该是跟刷新日志有关系,设置为0效率能够看到明显提升,当然,同样你可以SQL中提交“SET AUTOCOMMIT = 0”来设置达到好的性能。另外,还听说通过设置innodb_buffer_pool_size能够提升InnoDB的性能,但是我测试发现没有特别明显的提升。

基本上我们可以考虑使用InnoDB来替代我们的MyISAM引擎了,因为InnoDB自身很多良好的特点,比如事务支持、存储过程、视图、行级锁定等等,在并发很多的情况下,相信InnoDB的表现肯定要比MyISAM强很多,当然,相应的在my.cnf中的配置也是比较关键的,良好的配置,能够有效的加速你的应用。


    
 
 

您可能感兴趣的文章:

  • MySQL 重装MySQL后, mysql服务无法启动
  • 在Linux内安装了Mysql,无法进入Mysql.
  • Mysql 本地计算机无法启动 mysql 服务 错误 1067:进程意外终止。
  • ubuntu mysql配置错误导致无法启动mysql,希望达人前来帮助。
  • mysql服务无法启动报错误1067解决方法(mysql启动错误1067 )
  • 解决 phpmyadmin #2002 无法登录 MySQL 服务器
  • Linux安装的问题,phpMyadmin 无法管理MySQL,急!!
  • freebsd系统mysql无法启动求解
  • mysql无法登陆
  • linux 中phpmyadmin 无法载入mysql扩展,请检查php配置文档
  • 碰到MySQL无法启动1067错误问题解决方法
  • redhat9中,apach+php无法联接mysql
  • linux9.0 web mysql 服务正常 但是网页无法打开 请帮助?感谢!
  • 无法启动mysql
  • Linux 下zabbix server 无法启动,报mysql错误
  • MySQL无法启动、无法停止解决方法(安全设置后容易出现)
  • mysql增加新用户无法登陆解决方法
  • 在DEBIAN上手动安装MYSQL服务无法启动,请问是什么原因
  • MySQL连接无法解析HOST主机名的解决方法
  • redhatlinux9.0下mysql升级以后http服务无法启动问题
  • 解析mysql二进制日志处理事务与非事务性语句的区别
  • MySQL C API中有没有事务处理的函数啊?
  • mysql 事务 回滚 提交
  • 基于mysql事务、视图、存储过程、触发器的应用分析
  • MYSQL事务回滚的2个问题分析
  • 为mysql数据库添加添加事务处理的方法
  • Mysql中的事务是什么如何使用
  • mysql实现事务的提交和回滚实例
  • mysql 锁表锁行语句分享(MySQL事务处理)
  • mysql 事务处理及表锁定深入简析
  • MySql的事务使用与示例详解
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Mysql查询错误:ERROR:no query specified原因
  • windows7下启动mysql服务出现服务名无效的原因及解决方法
  • MySQL外键创建失败1005原因汇总
  • mysql执行时间为负数的原因分析
  • mysql安装时这是什么原因啊?小弟初学!
  • 在linux下安装mysql出错的原因,学习的机会、得分的机会、奉献的计划
  • 一台网络服务器,做web服务,有tomcat5.0, proftpd.mysql.经常down机,从哪些地方入手查找原因?
  • 100分给提示一下下面参数什么原因?Linux下MYSQL访问过多,谢谢
  • MySQL优化之如何查找SQL效率低的原因
  • mysql服务器查询慢原因分析与解决方法小结
  • 要慎用mysql的enum字段的原因
  • 逐步分析MySQL从库com_insert无变化的原因
  • MYSQL数据表损坏的原因分析和修复方法小结(推荐)
  • 我在使用 rpm 安装mysql软件时出现错误,请帮忙分析一下原因,谢谢
  • 深入探寻mysql自增列导致主键重复问题的原因
  • CSS属性参考手册 iis7站长之家
  • 在 linux下输入"mysql"命令,进入mysql命令行,但出现“Can't connetc to local MySQL server thuough socket /var/lib/mysql/mysql.sock
  • php安装完成后如何添加mysql扩展
  • 为什么用linux安装盘安装了mysql后,启动mysql,提示找不到mysql.sock文件?
  • mysql中查询当前正在运行的SQL语句并找出mysql中运行慢的sql语句
  • 請教,在redhat linux7.2+mysql 中,系統提示mysql已啟動,網頁卻不能訪問mysql?
  • Myeclipse中自带Tomcat的JDBC连接池配置(mysql和mssql)
  • 求解释: useradd -g mysql mysql -d /home/mysql -s /sbin/nologin
  • MySQL Workbench的下载安装与使用教程
  • 怎样在linux终端输入mysql直接进入mysql?
  • php中内置的mysql数据库连接驱动mysqlnd简介及mysqlnd的配置安装方式
  • c++中关于#include <mysql/mysql.h>的问题?
  • VS2012+MySQL+SilverLight5的MVVM开发模式介绍
  • mysql -u root mysql 怎么解释
  • MySQL索引基本知识
  • mm.mysql那里可以下载?www.mysql.com根本下载不了。谢谢了


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3