mysql引擎和事务

对于应用程序和用户来说,同样一张表的数据无论用什么引擎来存储,看到的数据都是一样的,只是不同的引擎在功能、占用空间大小、读取性能等方面可能有所差别。

mysql最常用的存储引擎为Innodb、MyISAM和全文索引

5.5.5以前默认存储引擎为MyISAM,5.5.5及之后默认存储引擎为Innodb

mysql> show engines \G查看当前数据库系统支持的引擎

mysql5.5支持事务的引擎:Innodb/ndb(集群的引擎)

对于MyISAM来说,每一个表对应于磁盘上的三个文件,这三个文件名称相同,扩展名不同。

.frm文件保存表的定义(是服务器而不是MyISAM引擎的一部分),.MYD保存表的数据,.MYI是表的索引文件(可参考mysql的系统库mysql下的文件)

特点:

1.不支持事务

2.表级锁定(更新时锁定整个表),锁定的成本小,但大大降低了并发性能

3.读写互相阻塞,不仅会在写入的时候阻塞读取,还会在读取的时候阻塞写入,但是读不会阻塞另外的读

4.只会缓存索引不能缓冲数据,可以通过key_buffer_size缓存索引,减少磁盘IO,但是只会缓存索引不会缓存数据

5.读取速度较快,占用资源相对少(功能相对弱,锁的粒度大)

6.不支持外键约束,但支持全文索引

7.mysql5.5.5默认的存储引擎

适用的生产场景:单一对数据库的操作(纯读或者纯写)可以使用

1.不需要事务支持的业务(例如转账、充值就不行)

2.一般为读多或者写多的网站应用,读写都频繁的场景不适合

3.读写并发相对较低的业务(纯读纯写高并发也可以)

4.数据修改相对较少的业务

5.以读为主的业务,例如www、blog、图片信息数据库

6.对数据一致性要求不很高的业务

7.硬件资源相对较差的机器

调优精要:

1.设置合适的索引

2.调整读写优先级,根据实际需要确保重要的操作更优先执行

3.启用延迟插入改善大批量写入性能(降低写入频率)

4.尽量顺序操作,让insert数据都写入到尾部,减少阻塞

5.分解大的时间长的操作,降低单个操作的阻塞时间

6.降低并发数,某些高并发场景通过应用进行排队队列机制

7.对于相对静态(更改不频繁)的数据库数据,充分利用query cache或者mamcached缓存服务极大的提高访问效率

8.count只有在全表扫描的时候高效,带有其他条件的count都需要进行实际的数据访问

9.可以把主从同步的主库使用Innodb,从库使用MyISAM引擎(不推荐)

Innodb

特点:

1.支持事务

2.行级锁定(更新时一般锁定当前行),通过索引实现,如果进行全表扫描仍然会锁全表与MyISAM相同,注意间隙锁的影响

3.读写阻塞与事务隔离级别相关

4.具有高效的缓存特性,能缓存索引,也能缓存数据

5.整个表和主键以cluster方式存储,组成一棵平衡树

6.所有secondary index都会保存逐渐信息

7.支持分区和表空间,类似oracle数据库

8.支持外键约束,5.5以前不支持全文索引,后续支持

9.与MyISAM相比对硬件资源要求相对较高

适用场景:

1.需要事务支持的业务

2.行级锁定对高并发有很好的适应能力,但需要确保查询通过索引完成

3.数据读写及更新都较为频繁的场景,如bbs、sns、微博、微信等

4.对数据一致性要求较高的业务,例如充值转账

5.硬件设备内存大,可以利用Innodb较好的缓存能力来提高内存利用率,尽可能减少磁盘IO

6.与MyISAM引擎相比,Innodb引擎更消耗资源,速度没有MyISAM快

调优精要:

1.主键尽可能小,避免给secondary index带来过大压力

2.避免全表扫描,否则会使用表锁

3.尽可能缓存所有的索引和数据,提高响应速度,减少磁盘IO消耗

4.在大批量小插入的时候,尽量自己控制事务,而不要使用autocommit

4.合理设置innodb_flush_log_at_trx_commit,不要过度追求安全性

5.避免主键更新,这会带来大量的数据移动

事务:逻辑上的一组sql语句操作,这组sql语句执行时要么全部成功要么全部失败

事务的四大特性ACID

原子性(atomicity):事务是一个不可分割的单位,一个事务中的所有sql操作要么全部成功要么全部失败

一致性(consistency):事务发生前和发生后,事务的完整性必须保持一致

隔离性(isolation):当并发访问数据库时,一个正在执行的事务在执行完毕前,对于其他会话是不可见的,多个并发事务之间的数据是互相隔离的(mysqldump时的参数--single-transaction)

持久性(durability):一个事务一旦被提交,它对数据库中的数据改变就是永久性的,如果出了错误,事务不允许撤销,只能通过“补偿性事务”

mysql数据库的事务默认是自动提交的。如果想多条sql在一个事务中执行,则需要使用事务进行处理。如果开启一个事务没有提交,mysql会自动回滚事务,或者手动使用rollback回滚。

start transaction开启事务

rollback回滚事务

commit提交事务

mysql> show variables like ‘%commit%‘;结果为on或者off(默认为on)

表创建后修改引擎的方法

1.mysql语句修改

mysql> alter table test2 engine=MyISAM;

2.使用sed对备份内容进行引擎替换,即用mysqldump备份,使用sed对引擎做替换,再导入替换后的备份语句

3.linux命令mysql_convert_table_format修改

原文地址:https://www.cnblogs.com/Forever77/p/10051278.html

时间: 2024-08-03 06:37:11

mysql引擎和事务的相关文章

MySQL数据库引擎、事务隔离级别、锁

MySQL数据库引擎.事务隔离级别.锁 数据库引擎InnoDB和MyISAM有什么区别 大体区别为: MyISAM类型不支持事务处理等高级处理,而InnoDB类型支持.MyISAM类型的表强调的是性能,其执行效率比InnoDB类型更快,但是不支持事务,而InnoDB提供事务支持以及外键等高级数据库功能. 具体实现的区别: InnoDB不支持FULLTEXT类型的索引 InnoDB中不保存表的具体行数,也就是说,执行查询SQL时,InnoDB要扫描一遍整个表来计算有多少行,而MyISAM只要简单的

什么是数据库的事务?MySql中哪些存储引擎支持事务?

什么是事务? 事务由一个或多个sql语句组成一个整体,如果所有的语句执行成功那么修改将会全部生效,如一条sql语句将销量+1,下一条再+1,倘若第二条失败,那么销量将撤销第一条sql语句的+1操作,只有在该事务中所有的语句都执行成功才会将修改加入到数据库中. 事务的特性 事务具体四大特性,也就是经常说的ACID 1. 原子性(Atomicity)  原子性是指事务包含的所有操作要么全部成功,要么全部失败回滚,因此事务的操作如果成功就必须要完全应用到数据库,如果操作失败则不能对数据库有任何影响. 

MySQL · 引擎特性 · InnoDB 事务系统

MySQL · 引擎特性 · InnoDB 事务系统 前言 关系型数据库的事务机制因其有原子性,一致性等优秀特性深受开发者喜爱,类似的思想已经被应用到很多其他系统上,例如文件系统等.本文主要介绍InnoDB事务子系统,主要包括,事务的启动,事务的提交,事务的回滚,多版本控制,垃圾清理,回滚段以及相应的参数和监控方法.代码主要基于RDS 5.6,部分特性已经开源到AliSQL.事务系统是InnoDB最核心的中控系统,涉及的代码比较多,主要集中在trx目录,read目录以及row目录中的一部分,包括

mysql数据库之 存储引擎、事务、视图、触发器、存储过程、函数、流程控制

目录 一.存储引擎 1.什么是存储引擎? 2.mysql支持的存储引擎 3. 使用存储引擎 二.事务 三.视图 1.什么是视图 2.为什么要用视图 3.如何用视图 四.触发器 为何要用触发器 创建触发器语法 五.存储过程 六.函数 七.流程控制 八.数据库备份(运维方向) 一.存储引擎 1.什么是存储引擎? mysql中建立的库===>文件夹 库中建立的表===>文件 现实生活中我们用来存储数据的文件有不同的类型,每种文件类型对应各自不同的处理机制:比如处理文本用txt类型,处理表格用exce

MySQL——索引视图事务,存储引擎MyLSAM和InnoDB(实战篇!)

索引的作用 设置了合适的索引之后,数据库利用各种快速的定位技术,能够大大加快查询速率: 特别是当表很大时,或者查询涉及到多个表时,使用索引可使查询加快成千倍: 可以降低数据库的IO成本,并且索引还可以降低数据库的排序成本: 通过创建唯一性索引保证数据表数据的唯一性: 可以加快表与表之间的连接: 在使用分组和排序时,可大大减少分组和排序时间: 1,进入数据库,创建数据库,创建表 [[email protected] ~]# mysql -uroot -p ##进入数据库 Enter passwor

MySQL索引与事务、存储引擎MyISAM和InnoDB (理论+实践篇)

索引的概念 数据库中的索引与书籍中的目录类似 在一本书中,无须阅读整本书,利用目录就可以快速查找所需信息 书中的目录是一个词语列表,其中注明了包含各个词的页码 数据库索引 在数据库中,索引使数据库程序无须对整个表进行扫描,就可以在其中找到所需数据 数据库中的索引|是某个表中一-列或者若干列值的集合,以及物理标识这些值的数据页的逻辑指针清单 索引的的作用 设置了合适的索引之后,数据库利用各种快速的定位技术,能够大大加快查询速率 特别是当表很大时,或者查询涉及到多个表时,使用索引可使查询加快成3 F

MySQL索引与事务,视图,存储引擎MylSAM和lnnoDB

MySQL索引与事务,视图,存储引擎MylSAM和lnnoDB 索引的概念 数据库中的索引与书籍中的目录类似: 1.-本书中,无须阅读整本书,利用目录就可以快速查找所需信息2.书中的目录是一个词语列表,其中注明了包含各个词的页码 数据库索引: 1.在数据库中,索弓|使数据库程序无须对整个表进行扫描,就可以在其中找到所需数据2.数据库中的索弓|是某个表中一-列或者若干列值的集合,以及物理标识这些值的数据页的逻辑指针清单 索引的作用: 1.设置了合适的索引之后,数据库利用各种快速的定位技术,能够大大

mysql引擎和mysql日志相关总结

mysql日志 01.错误日志: 可以在my.cnf里面配置: [mysqld_safe] log-error=/data/3306/mysql_qb3306.err 02.查询日志 普通查询日志:纪录客户端连接信息和执行的sql语句信息(由于占用内存,作用也不是很大,就一般是关着的) mysql> show variables like 'general_log%'; +------------------+--------------------------+ | Variable_name

漫谈MySql中的事务

最近一直在做订单类的项目,使用了事务.我们的数据库选用的是MySql,存储引擎选用innoDB,innoDB对事务有着良好的支持.这篇文章我们一起来扒一扒事务相关的知识. 为什么要有事务? 事务广泛的运用于订单系统.银行系统等多种场景.如果有以下一个场景:A用户和B用户是银行的储户.现在A要给B转账500元.那么需要做以下几件事: 1. 检查A的账户余额>500元: 2. A账户扣除500元: 3. B账户增加500元: 正常的流程走下来,A账户扣了500,B账户加了500,皆大欢喜.那如果A账