【Mysql】(1)简单认识Mysql

【Mysql】(1)简单认识Mysql

  • (1)MySQL基本介绍
  • (2)存储引擎
      • (2.1)MyISAM和InnoDB区别
          • (2.1.1)两者对比
          • (2.1.2)认识一下MVCC(多版本并发控制:Multiversion Concurrency Control)

(1)MySQL基本介绍

MySQL 是一种关系型数据库,默认端口号是3306

(2)存储引擎

(2.1)MyISAM和InnoDB区别

在5.5版之前,MySQL的默认数据库引擎是MyISAM,虽然性能极佳,而且提供了大量的特性,包括全文索引、压缩、空间函数等,但MyISAM不支持事务和行级锁,而且最大的缺陷就是崩溃后无法安全恢复

不过,5.5版本之后,MySQL引入了InnoDB(事务性数据库引擎),MySQL 5.5版本后默认的存储引擎为InnoDB。大多数时候我们使用的都是 InnoDB 存储引擎,但是在某些情况下使用 MyISAM 也是合适的比如读密集的情况下。(如果你不介意 MyISAM 崩溃恢复问题的话)。

(2.1.1)两者对比

(1)是否支持行级锁?
MyISAM 只有表级锁(table-level locking),而InnoDB 支持行级锁(row-level locking)和表级锁,默认为行级锁。

(2)是否支持事务和崩溃后的安全恢复?
MyISAM 强调的是性能,每次查询具有原子性,其执行速度比InnoDB类型更快,但是不提供事务支持。
但是InnoDB 提供事务支持事务,外部键等高级数据库功能。 具有事务(commit)、回滚(rollback)和崩溃修复能力(crash recovery capabilities)的事务安全(transaction-safe (ACID compliant))型表。

(3)是否支持外键?
MyISAM不支持,而InnoDB支持。

(4)是否支持MVCC?
仅 InnoDB 支持。应对高并发事务, MVCC比单纯的加锁更高效;MVCC只在 READ COMMITTED 和 REPEATABLE READ 两个隔离级别下工作;MVCC可以使用 乐观(optimistic)锁 和 悲观(pessimistic)锁来实现;各数据库中MVCC实现并不统一。

(2.1.2)认识一下MVCC(多版本并发控制:Multiversion Concurrency Control)

多版本控制: 指的是一种提高并发的技术。最早的数据库系统,只有读读之间可以并发,读写,写读,写写都要阻塞。引入多版本之后,只有写写之间相互阻塞,其他三种操作都可以并行,这样大幅度提高了InnoDB的并发度。在内部实现中,与Postgres在数据行上实现多版本不同,InnoDB是在undolog中实现的,通过undolog可以找回数据的历史版本。找回的数据历史版本可以提供给用户读(按照隔离级别的定义,有些读请求只能看到比较老的数据版本),也可以在回滚的时候覆盖数据页上的数据。在InnoDB内部中,会记录一个全局的活跃读写事务数组,其主要用来判断事务的可见性。

链接:MVCC介绍

你可能感兴趣的:(Java基础与算法)