MySQL系列(13): 索引 之 Hash索引 与 B-Tree索引
了解 B-tree 和 Hash 数据结构,有助于预测不同的查询在不同的存储引擎上使用这些数据结构的执行情况。特别是对于允许选择 B-tree 和 Hash 索引的内存存储引擎(MEMORY)。
InnoDB 存储引擎默认使用的是 B-tree 数据结构的索引。官方文档:B-tree 索引 与 Hash 索引比较
了解 B-tree 和 Hash 数据结构,有助于预测不同的查询在不同的存储引擎上使用这些数据结构的执行情况。特别是对于允许选择 B-tree 和 Hash 索引的内存存储引擎(MEMORY)。
InnoDB 存储引擎默认使用的是 B-tree 数据结构的索引。官方文档:B-tree 索引 与 Hash 索引比较
MyISAM存储引擎只支持表级锁。该锁类型是也使用非常广泛的锁类型。
加锁操作是为了保证多事务操作同一数据时可能保持一致性。有 悲观锁 和 乐观锁 两种方式。
悲观锁 是由数据库引擎提供支持;乐观锁 是常规 SQL 语句版本检测的一种主观理解。
锁是计算机协调多个进程或并发访问某一资源的机制,数据也是供许多用户共享的资源。Java有锁机制,数据库也有锁机制。数据库锁定机制简单来说,是为了保证在并发情况下数据的一致性、有效性。
MySQL的锁机制是由存储引擎提供的,InnoDB
存储引擎支持行级锁和表级锁,默认级别行级锁(row-Level locking); MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking),BDB存储引擎采用的是页面锁(page-level locking),也支持表级锁,BDB已成为历史。
InnoDB 与 MyISAM 最大的不同有两点:一是支持事务,二是采用行级锁。
MySQL 5.7 官方文档:14.7.1 InnoDB Locking,14.7.3 Locks Set by Different SQL Statements in InnoDB,14.7.5 Deadlocks in InnoDB。
事务(Transaction )是InnoDB
存储引擎一个很重要并且区别于其它存储引擎的特性。 使用了 Innodb 存储引擎的数据库或表才支持事务。
事务:指作为单个逻辑工作单元执行的一组操作,这组操作的各个单元要么全部成功,要么全部失败。
事务处理:通过将一组相关操作组合为一个要么全部成功,要么全部失败的单元,保证数据一致性。
MySQL 5.7.5 版本,默认开启了only_full_group_by
模式,select
字段只能是group by的字段,否则会报错,可以关闭该模式,或使用 any_value(column)
来抑制该异常。
防止在生产中使用 update
语句漏带条件导致全表更新事故,开启安全更新模式,强制带条件更新,否则报错。
MySQL 默认支持多种存储引擎,提供了灵活的存储,以支持不同场景的应用。
MySQL 8.0 版本,默认使用 InnoDB
存储引擎,即建表语句(CREATE TABLE
) 不带 ENGINE=子句会创建 InnoDB 表。
关于 MySQL 存储引擎,可以单独写成一个系列文章,后续有时间列入计划中。The InnoDB Storage Engine - 官网,lternative Storage Engines - 替代引擎
经常需要查询一段日期范围内的数据,可能需要对日期时间进行格式转换以达到真正想要的数据,这里整理了几种方式。
整理下以前记录的一些常用但一时想不起的 SQL 语句,有些极其简单,有些则需要思考下。
MySQL 提供了丰富的函数,可以帮助编写简单快捷的 SQL 语句。比如字符串处理、数值运算、日期运算等。
常用的函数有字符串函数、日期函数、数值函数、聚合函数,还有 全文检索函数、转换函数、XML函数、位操作函数、加密解密函数、锁函数、MySQL信息函数、几何函数、空间函数、JSON 函数、MySQL 企业加密函数、其它函数。
此篇文章目的是作为字典,看过一遍先了让自己有个映像有些函数可以实现某些功能,具体需要使用再查询,多用几次就记住了。