一、关系型数据库与非关系型数据库

 1.关系型数据库的特点:

  1)数据以表格的形式出现

  2)每行为各种记录名称

  3)每列为记录名称所对应的数据域

  4)许多的行和列组成一张表单

  5)若干的表单组成数据库

 2.关系型数据库的优势:

   2.1 复杂的查询:可以使用SQL语句方便地在一个表以及多个表之间做非常复杂的数据查询。

   2.2 事务支持:使得对于安全性能很高的数据访问要求得以实现。

 3.非关系型数据库的优势:

   3.1 性能:NOSQL是基于键值对的,可以想象成表中的主键和值的对应关系,而且不需要经过SQL层的解析,所以性能非常高。

   3.2 可扩展性:同样也是因为基于键值对,数据之间没有耦合性,所以非常容易水平扩展。

 问题:三种传统数据库之间的区别?

  答:三者之间是根据数据之间的联系而去别的,层次性数据库是树形结构、网状型数据库是链接指针结构、关系型数据库是二维表结构。

二、事务(ACID)

  事务(transaction)是作为单个逻辑工作单元执行的一系列操作,这些操作作为一个整体一起向系统提交,要么都执行,要么都不执行。事务是一个不可分割的工作逻辑单元。

  事务必须具备以下四个属性,简称ACID属性:

    原子性(atomicity):事务是一个完整的操作。事物的各部操作是不可分的(原子的);要么都执行,要么都不执行;

    一致性(consistency):当事务完成时,数据必须处于一致状态;

    隔离性(isolation):对数据进行修改的所有并发事务是彼此隔离的,这表明事务必须是独立的,它不应以任何形式依赖于或影响其他事务;

    永久性(durability):事务完成后,它对数据库的修改是永久的,事务日志能够保持事务的永久性。

  事务的隔离级别:

    读取未提交内容(又称为脏读 read uncommitted):指所有事务都可以看到其他未提交事务的执行结果。可能有脏读、不可重复读和幻读问题。

    读取提交内容(read commited):一个事务只能看见已经提交的事务所做的改变。可以避免脏读,可能有不可重复读和幻读问题。

    可重复读(repeatable read):是MySQL的默认事务隔离级别,它确保同一事务的多个实例在并发读取数据时,会看到同样的数据行。可以避免脏读和不可重复读,可能会有幻读问题。

    可串行化(serializable):是最高的隔离级别,它通过在每个读的数据行上加上共享锁,使之不可能相互冲突,从而解决幻读问题。可以避免脏读、不可重复读、幻读。

  并发事务带来的问题:

    1.更新丢失:两个事务T1和T2读入了同一数据并修改,T2提交的结果覆盖了T1提交的结果,导致T1的修改被丢失。

    2.脏读:事务T1修改了某一数据,并将其写回磁盘,事务T2读取同一数据后,T1由于某种原因被撤销,这时T1已修改过的数据恢复原值,T2读到的数据就与数据库中的数据不一致,则T2读到的数据就为“脏”数据,即不正确的数据。

    3.不可重复读:是指在一个事务内,多次读同一数据。在这个事务还没有结束时,另外一个事务也访问了该同一数据。那么,在第一个事务中的两次读数据之间,由于第二个事务的修改,那么第一个事务两次读到的数据可能是不一样的。这就发生了在一个事务内两次相同的查询读到的数据是不一样的,因此称为是不可重复读。

    4.幻读:例如:目前工资为5000的员工有10人,事务A读取所有工资为5000的人数为10人。此时,事务B插入了一条工资也为5000的记录。这时,事务A再次读取工资为5000的员工,记录为11人。此时就产生了幻读。

   不可重复读和幻读的区别?不可重复读的重点是修改,幻读的重点在于新增或删除。

   MVCC(多版本并发控制机制):InnoDB的MVCC,是通过在每行记录后面保存两个隐藏的列来实现的。分别保存了行的创建时间和行的删除时间(这里存储的并不是实际的时间值,而是系统版本号)。每开始一个新的事务,系统版本号都会自动递增。事务开始时刻的系统版本号会作为事务的ID,用来和查询到的每行记录的版本号进行比较,使用MVCC后可重复读隔离级别下不会出现幻读现象。

三、存储引擎

  存储引擎是数据库底层软件组织,数据库管理系统(DBMS)使用数据引擎进行创建、查询、更新和删除数据。

  1.InnoDB(聚集索引方式)

    innodb底层存储结构为B+树,树的每个节点对应innodb的一个page,page的大小是固定的,一般设为16K.其中非叶子节点只有键值,叶子节点包含完整数据。

    使用场景:1)经常更新的表,是和处理多重并发的更新请求;

         2)支持事务安全表(ACID),支持行锁和外键;

         3)可以通过bin-log日志等恢复

    innodb如果没有设置主键,就会自动生成一个6字节的主键(用户不可见)。

  2.MyISAM(非聚簇索引方式)

    MyISAM在5.1之前是MySQL的默认存储引擎,它强调的是性能,但是它不支持事务、也不支持行锁和外键,支持表锁;当插入或更新数据时,需要锁住整个表,效率便会低一些。只缓存索引,不缓存真实数据。MyISAM读取数据时速度很快,而且不占用大量的内存和存储资源。

    MyISAM允许没有主键的存在,是一种静态索引结构。

  问题:MySQL中MyISAM与InnoDB的区别?

   答:MySQL数据库中,最常用的两种引擎是innodb和myisam。InnoDB是目前MySQL的默认存储引擎。

     1)事务方面:MyISAM强调的是性能,查询速度比InnoDB类型更快,但是不支持事务。InnoDB提供事务支持。

     2)外键:MyISAM不支持外键,InnoDB支持外键。

     3)锁:MyISAM只支持表级锁,InnoDB支持行级锁和表级锁,默认为行级锁,行锁大幅度提高了多用户并发操作的性能。innodb比较适合于插入和更新操作比较多的情况,而myisam则适合于频繁查询的情况。另外,innodb表的行锁也不是绝对的,如果在执行一个SQL语句时,MySQL不能确定要扫描的范围,innodb同样会锁全表,例如:update table set num=1 where name like "%aaa%"。

     4)全文索引:MyISAM支持全文索引,Innodb不支持全文索引。innodb从MySQL5.6之后提供全文索引的支持。

     5)表主键:myisam允许没有主键的表存在;innodb:如果没有设定主键,就会自动生成一个6字节的主键(用户不可见)。

     6)表的具体行数:myisam:select count(*) from table,myisam只要简单的读出保存好的行数。因为myisam内置了一个计数器,count(*)时它直接从计数器中读。

               innodb:不保存表的具体行数,也就是说,执行select count(*) from table 时,innodb要扫描一遍整个表来计算有多少行。

MySQL数据库的事务及存储引擎的更多相关文章

  1. MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述

    MySQL存储引擎的实际应用以及对MySQL数据库中各主要存储引擎的独特特点的描述: 1.MySQL有多种存储引擎: MyISAM.InnoDB.MERGE.MEMORY(HEAP).BDB(Berk ...

  2. MySQL 索引、事务与存储引擎

               MySQL 索引.事务与存储引擎 1.索引 2.事务 3.存储引擎 1.索引: 索引的概念 : 索引是一个排序的列表,在这个列表中存储着索引的值和包含这个值的数据所在行的物理地址 ...

  3. 27.MySQL 索引、事务与存储引擎

    MySQL 索引.事务与存储引擎 目录 MySQL 索引.事务与存储引擎 MySQL 索引 索引的概念 索引的作用及副作用 索引的作用 索引的副作用 创建索引的原则依据 索引的分类和创建 普通索引 唯 ...

  4. Mysql数据库的触发器、存储引擎和存储过程

    数据库的触发器 1.触发器 触发器是MySQL响应以下任意语句而自动执行的一条MySQL语句(或位于BEGIN和END语句之间的一组语句): DELETE,INSERT,UPDATE 我们可以监视某表 ...

  5. MySQL索引、事务、存储引擎

    一.MySQL 索引 1.索引的概念 ●索引是一个排序的列表,在这个列表中存储着索引的值和包含这个值的数据所在行的物理地址(类似于C语言的链表通过指针指向数据记录的内存地址).●使用索引后可以不用扫描 ...

  6. 【转】MySQL数据库MyISAM和InnoDB存储引擎的比较

    MySQL有多种存储引擎,MyISAM和InnoDB是其中常用的两种.这里介绍关于这两种引擎的一些基本概念(非深入介绍). MyISAM是MySQL的默认存储引擎,基于传统的ISAM类型,支持全文搜索 ...

  7. MySQL数据库MyISAM和InnoDB存储引擎的比较

    MySQL有多种存储引擎,MyISAM和InnoDB是其中常用的两种.这里介绍关于这两种引擎的一些基本概念(非深入介绍). MyISAM是MySQL的默认存储引擎,基于传统的ISAM类型,支持全文搜索 ...

  8. MySQL数据库MyISAM和InnoDB存储引擎的比较(转)

    MySQL有多种存储引擎,MyISAM和InnoDB是其中常用的两种.这里介绍关于这两种引擎的一些基本概念(非深入介绍). MyISAM是MySQL的默认存储引擎,基于传统的ISAM类型,支持全文搜索 ...

  9. MySQL数据库MyISAM和InnoDB存储引擎的比较【转载】

    转自 http://www.cnblogs.com/panfeng412/archive/2011/08/16/2140364.html MySQL有多种存储引擎,MyISAM和InnoDB是其中常用 ...

随机推荐

  1. Redis缓存与数据库一致性解决方案

    背景 缓存是数据库的副本,应用在查询数据时,先从缓存中查询,如果命中直接返回,如果未命中,去数据库查询最新数据并返回,同时写入缓存. 缓存能够有效地加速应用的读写速度,同时也可以降低后端负载.是应用架 ...

  2. Jmeter正则提取请求响应数据

    前言 在测试时,我们经常需处理请求返回的响应数据,比如很多时候 cookie 或 token 或 Authorization授权码 会返回在 Response headers(响应头)中,这时我们便需 ...

  3. SpringBoot2.0 整合 Shiro 框架,实现用户权限管理

    本文源码:GitHub·点这里 || GitEE·点这里 一.Shiro简介 1.基础概念 Apache Shiro是一个强大且易用的Java安全框架,执行身份验证.授权.密码和会话管理.作为一款安全 ...

  4. 解析innodb中的MVCC

    本人免费整理了Java高级资料,涵盖了Java.Redis.MongoDB.MySQL.Zookeeper.Spring Cloud.Dubbo高并发分布式等教程,一共30G,需要自己领取.传送门:h ...

  5. pecl安装和卸载示例

    比如安装MongoDB扩展 命令行下输入: [#] /usr/local/php/bin/pecl install mongodb ......嗒吧嗒吧一大堆输出后 Build process com ...

  6. JMeter命令行执行+生成HTML报告

    1.为什么用命令行模式 使用GUI方式启动jmeter,运行线程较多的测试时,会造成内存和CPU的大量消耗,导致客户机卡死: 所以一般采用的方式是在GUI模式下调整测试脚本,再用命令行模式执行: 命令 ...

  7. QT解决中文乱码

    如果编译器在支持C++11的情况下,我们可以使用u8"XXXX" 如:QString str = u8"我是中文"; 这样就解决了中文乱码的问题,使用UTF-8 ...

  8. Flask报如下错误:SQLALCHEMY_TRACK_MODIFICATIONS adds significant overhead and will be disabled by default in the future. Set it to True or False to suppress this warning.

    在同一个项目中由于flask_sqlalchemy版本不同,有时会报如下错误 错误信息如下: flask_sqlalchemy\__init__.py:: UserWarning: SQLALCHEM ...

  9. Druid-代码段-2-1

    所属文章:池化技术(一)Druid是如何管理数据库连接的? 本代码段对应主流程2,具体用来初始化整个连接池: public void init() throws SQLException { if ( ...

  10. Python迭代器的用法,next()方法的调用

    迭代器的用法: 首先说两个概念,一个是可迭代的对象,一个是迭代器对象,两个不同 可迭代的(Iterable):就是可以for循环取数据的,比如字典.列表.元组.字符串等,不可使用next()方法. 迭 ...