MySQL8.0之数据字典

  • 时间:
  • 浏览:0

8.0中对数据字典进行改进之前 ,很大程度上提高了对INFORMATIONS_SCHEMA的查询性能,通过可否 通过查表快速的获得我想要查询的数据,原困是:

(2)原子DDL

新数据字典带来的影响

在8.0之前 版本中,innodb_read_only参数可否 阻止对InnoDB存储引擎表的create和drop等更新操作。或者在MySQL8.0中,开启innodb_read_only参数阻止了所有存储引擎的哪此操作。create机会drop表的操作都可否 更新数据字典表,8.0中你你这个 数据字典表都改为了InnoDB存储引擎,越多对于数据字典表的更新会失败,从而原困各存储引擎create和drop表失败。同样的像ANALYZE TABLEALTER TABLE tbl_name ENGINE=engine_name你你这个 操作也会失败,机会哪此操作都会 去更新数据字典表。

MySQL 8.0 将数据库元信息都存放于InnoDB存储引擎表中,在之前 版本的MySQL中,数据字典不仅仅存放于特定的存储引擎表中,还存放于元数据文件、非事务性存储引擎表中。本文机会介绍MySQL 8.0对数据字典的改进,以及改进带来的好处、影响以及局限性。

(4)mysqldump mysqlpump导出的内容影响

MySQL8.0数据字典的改进有越多方便的行态,例如带来了原子DDL,提升了INFORMATION_SCHEMA的查询性能等,或者它并都会 完美的,新版数据字典还是居于或多或少局限性:

 数据字典

(3)innodb_read_only对所有存储引擎生效

最新的MySQL 8.0 发布之前 ,对数据库数据字典方面做了较大的改进。

information_schema_stats_expiry参数为0机会ANALYZE TABLE操作。

(1)新版本之前 的数据字典

MySQL8.0之前 ,在使用mysqldump和mysqlpump导出数据之前 ,与之前 有了或多或少不同,主假使 以下几点:

目前机会正式GA的MySQL 8.0是令人很期待的那我版本,从数据字典方面的改进,到原子DDL,到数据库self tuning等等新行态,都我就为8.0感到激动。8.0蕴藏或多或少新行态等待的图片 去尝试,去发现。

本文作者:沈 刚·沃趣科技

本文来自云栖社区公司协作 伙伴“老叶茶馆”,了解相关信息可否 关注“老叶茶馆”。

.frm,.opt,.par,.TRN,.TRG,.isl文件都移除了,不再通过文件的办法存储数据字典信息。其次是对INFORMATION_SCHEM,mysql,sys系统库中的存储引擎做了改进,那我使用MyISAM存储引擎的数据字典表都改为使用InnoDB存储引擎存放。无须支持事务的MyISAM存储引擎转变到支持事务的InnoDB存储引擎,为原子DDL的实现,提供了机会性。

(1)INFORMATION_SCHEMA性能提升

原文发布时间为:2018-05-17

DDL操作会花费更长的时间,机会之前 的DDL操作是直接对.frm文件进行更改操作,假使 写那我文件,现在是可否 更新数据字典表,代表着可否 将数据写到存储引擎、read log、undo log中。

(5)新数据字典的局限性

MySQL8.0开始英文英文支持原子DDL操作,那我原子DDL操作,具体的操作内容包括:数据字典更新,存储引擎层的操作,在binlog中记录DDL操作。或者哪此操作都会 原子性的,表示里边过程出显错误的之前 ,是可否 完正回退的。这在之前 版本的DDL操作中是不支持的。之前 数据库版本中老会 没法支持原子DDL的行态,是有原困的,机会在早期的数据库版本中,数据库元信息存放于元信息文件中、非事务性表中以及特定存储引擎的数据字典中。哪此都无法保证DDL操作内容在那我事务当中,无法保证原子性。

具体的原子DDL,后续会有专门的文章。

数据字典是数据库重要的组成每段之一,没法哪此是数据字典?数据字典蕴藏哪此内容呢?数据字典是对数据库中的数据、库对象、表对象等的元信息的集合。在MySQL中,数据字典信息内容就包括表行态、数据库名或表名、字段的数据类型、视图、索引、表字段信息、存储过程、触发器等内容。MySQL INFORMATION_SCHEMA库提供了对数据局元数据、统计信息、以及有关MySQL server的访问信息(例如:数据库名或表名,字段的数据类型和访问权限等)。该库中保存的信息也可否 称为MySQL的数据字典。

information_schema_stats_expiry参数设置缓存数据的过期时间,默认是86400秒。查询这两张表的数据的之前 ,首先是到缓存中进行查询,缓存中没法缓存数据,机会缓存数据过期了,查询会从存储引擎中获取最新的数据。机会可否 获取最新的数据,可否 通过设置

总结

在MySQL8.0之前 ,MySQL的数据字典信息,并没法完正存装入 系统数据库表中,每段数据库数据字典信息存放于文件中,其余的数据字典信息存放于数据字典库中(INFORMATION_SCHEMA,mysql,sys)。例如表行态信息存装入 .frm文件中,数据库表字段信息存放于INFORMATION_SCHEMA下的COLUMNS表中。早期,5.6版本之前 ,MyISAM是MySQL的默认存储引擎,而作为MyISAM存储引擎,它是没法数据字典的。只能表行态信息记录在.frm文件中。MySQL5.6版本之前 ,将InnoDB存储引擎作为默认的存储引擎。在InnoDB存储引擎中,上加了或多或少数据字典文件用于存放数据字典元信息,例如:.opt文件,记录了每个库的或多或少基本信息,包括库的字符集等信息,.TRN.TRG文件用于存放触发器的信息内容。

(2)新版本数据字典的改进

之前 版本中,导出触发器、存储过程可否 一起去导出触发器、存储过程的创建和修改的时间戳,8.0中不再支持。

对于INFORMATION_SCHEMA下的STATISTICS表和TABLES表中的信息,8.0中通过缓存的办法,以提高查询的性能。可否 通过设置