MySQL8.0之数据字典

  • 时间:
  • 浏览:1

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

8.0中对数据字典进行改进时候,很大程度上提高了对INFORMATIONS_SCHEMA的查询性能,通过可不可以通过查表快速的获得让你查询的数据,意味着是:

新数据字典带来的影响

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

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

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

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

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

MySQL8.0时候,在使用mysqldump和mysqlpump导出数据时候,与时候有了一些不同,主要是 我以下几点:

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

总结

 数据字典

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

(1)INFORMATION_SCHEMA性能提升

DDL操作会花费更长的时间,将会时候的DDL操作是直接对.frm文件进行更改操作,只要写有有有有两个文件,现在是可不可以更新数据字典表,代表着可不可以将数据写到存储引擎、read log、undo log中。

目前将会正式GA的MySQL 8.0是令人很期待的有有有有两个版本,从数据字典方面的改进,到原子DDL,到数据库self tuning等等新形态学 ,都我能 为8.0感到激动。8.0所含一些新形态学 等待图片去尝试,去发现。

MySQL8.0数据字典的改进有一些一些方便的形态学 ,类事带来了原子DDL,提升了INFORMATION_SCHEMA的查询性能等,时候它并有的是完美的,新版数据字典还是居于一些局限性:

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

(1)新版本时候的数据字典

MySQL8.0始于了了支持原子DDL操作,有有有有两个原子DDL操作,具体的操作内容包括:数据字典更新,存储引擎层的操作,在binlog中记录DDL操作。时候一些操作有的是原子性的,表示后边过程出显错误的时候,是可不可以完整回退的。这在时候版本的DDL操作中是不支持的。时候数据库版本所含晒 两个劲没法支持原子DDL的形态学 ,是有意味着的,将会在早期的数据库版本中,数据库元信息存放于元信息文件中、非事务性表中以及特定存储引擎的数据字典中。一些都无法保证DDL操作内容在有有有有两个事务当中,无法保证原子性。

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

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

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

本文来自云栖社区相互相互合作伙伴“老叶茶馆”,了解相关信息可不可以关注“老叶茶馆”。

在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)原子DDL

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

在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对数据字典的改进,以及改进带来的好处、影响以及局限性。

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