写点什么

MySQL 8.0 数据字典有什么变化

作者:GreatSQL
  • 2023-03-09
    福建
  • 本文字数:1702 字

    阅读完需:约 6 分钟

MySQL 8.0数据字典有什么变化
  • GreatSQL 社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。

  • GreatSQL 是 MySQL 的国产分支版本,使用上与 MySQL 一致。

  • 作者: 叶金荣

  • 文章来源:GreatSQL 社区原创



1. MySQL 8.0 数据字典有什么变化

从 MySQL 8.0 开始,采用独立表空间模式的每个 InnoDB 表只有一个 .ibd 表空间文件,而不再有 .frm 文件了。为了实现 DDL 的原子性,InnoDB 直接把元数据存储在表空间文件中,需要的话,可是使用 ibd2sdi 工具从中读取,例如:


$ ibd2sdi test/t1.sdi["ibd2sdi",{        "type": 1,        "id": 1268,        "object":                {    "mysqld_version_id": 80031,    "dd_version": 80023,    "sdi_version": 80019,    "dd_object_type": "Table",...{        "type": 2,        "id": 29,        "object":                {    "mysqld_version_id": 80031,    "dd_version": 80023,    "sdi_version": 80019,    "dd_object_type": "Tablespace",    "dd_object": {        "name": "test/t1",        "comment": "",        "options": "autoextend_size=0;encryption=N;",        "se_private_data": "flags=16417;id=24;server_version=80031;space_version=1;state=normal;",        "engine": "InnoDB",        "engine_attribute": "",        "files": [            {                "ordinal_position": 1,                "filename": "./test/t1.ibd",                "se_private_data": "id=24;"            }        ]    }}}]
复制代码


如果是 MyISAM 引擎表,也不再有 .frm 文件,而是采用 .sdi 文件来记录元数据信息。


在 .sdi 文件中,采用 JSON 格式存储元数据信息。


对于 MyISAM 表,不能再像以前那样,直接把 .frm.MYD.MYI 文件拷贝到目标数据库后就能直接用。方法改成了类似下面这样的:


# 首先拷贝数据及索引文件到目标数据库$ cp -p ./db1/t1.MYD ./db1/t1.MYI ./db2
# 拷贝 .sdi 文件到 secure_file_priv 指定的路径下$ cp -p ./db1/t1_1274.sdi $secure_file_priv/
# 修改 .sdi 文件中的 schema 值,将 db1 改成 db2# MySQL文档中没提到这点,但实测过程中发现需要加这步操作$ vim $secure_file_priv/t1_1274.sdi..."schema_ref":"db1" #此处修改成 "schema_ref":"db2"...
# 执行导入操作mysql> IMPORT TABLE FROM '$secure_file_priv/t1_1274.sdi';
复制代码


上文中的 $secure_file_priv 需要自行替换成实际路径。


另外,.sdi 文件名前面的数字,**是该表的隐藏 ID,每次新建一个表,这个值都会顺序增加,**类似 InnoDB 表的 TABLE_ID 值(这里说的是类似,二者不等价)。

2. 怎么查看每个/某个 session 里设置的 variables

查看 performance_schema.variables_by_thread 即可


select * from variables_by_thread where VARIABLE_NAME = 'sort_buffer_size';+-----------+------------------+----------------+| THREAD_ID | VARIABLE_NAME    | VARIABLE_VALUE |+-----------+------------------+----------------+|     29310 | sort_buffer_size | 4194304        ||     29375 | sort_buffer_size | 4194304        ||     29378 | sort_buffer_size | 32768          |  -- 在这个session里修改成其他非默认设置值|     29209 | sort_buffer_size | 4194304        |+-----------+------------------+----------------+
复制代码


再根据 THREAD_ID 列和 performance_schema.threads 关联查询,即可知道每个/某个 session 里的 variables 是否有自定义设置了。

3. mysqlpump 备份并不好用

用 mysqlpump 备份时,默认是不会备份用户授权信息的,需要类似这样 mysqlpump --exclude-databases=% --users 单独指定选项才能额外备份用户授权信息。




Enjoy GreatSQL :)

关于 GreatSQL

GreatSQL 是由万里数据库维护的 MySQL 分支,专注于提升 MGR 可靠性及性能,支持 InnoDB 并行查询特性,是适用于金融级应用的 MySQL 分支版本。


相关链接: GreatSQL社区 Gitee GitHub Bilibili

GreatSQL 社区:

社区博客有奖征稿详情:https://greatsql.cn/thread-100-1-1.html


技术交流群:

微信:扫码添加GreatSQL社区助手微信好友,发送验证信息加群



用户头像

GreatSQL

关注

GreatSQL社区 2023-01-31 加入

GreatSQL是由万里数据库维护的MySQL分支,专注于提升MGR可靠性及性能,支持InnoDB并行查询特性,是适用于金融级应用的MySQL分支版本。 社区:https://greatsql.cn/ Gitee: https://gitee.com/GreatSQL/GreatSQL

评论

发布
暂无评论
MySQL 8.0数据字典有什么变化_MySQL_GreatSQL_InfoQ写作社区