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

...
{ "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;" } ] }}}]1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.16.17.18.19.20.21.22.23.24.25.26.27.28.29.30.31.32.33.34.35.36.37.38.39.40.如果是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;1.2.3.4.5.6.7.8.9.10.11.12.13.14.15.上文中的 $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 |
+-----------+------------------+----------------+1.2.3.4.5.6.7.8.9.再根据 THREAD_ID 列和 performance_schema.threads 关联查询,即可知道每个/某个session里的variables是否有自定义设置了。
3. mysqlpump备份并不好用
用mysqlpump备份时,默认是不会备份用户授权信息的,需要类似这样 mysqlpump --exclude-databases=% --users 单独指定选项才能额外备份用户授权信息。
网站模板相关文章
格兰仕15升烤箱的实用性与功能性剖析(高效、多功能、易操作,揭秘格兰仕15升烤箱的独特魅力)
摘要:格兰仕15升烤箱是一款备受欢迎的小型厨房电器,其紧凑的尺寸和出色的功能使其成为现代家庭烹饪的理想之选。本文将从高效性、多功能性和易操作性三个方面对格兰仕15升烤箱进行深入剖析,以揭...2025-11-05- 美国联邦调查局(FBI)本周三证实,对全球最大肉类包装公司 JBS 发起持续勒索软件攻击的幕后黑手,就是臭名昭著的网络犯罪集团 REvil(又称Sodinokibi)。在事件曝光当天晚些时候发布的一份2025-11-05
SQL Server 2005数据库中的自定义类型的实例演示
复制publicvoidRead(System.IO.BinaryReaderr) { this.ageGroup=r.ReadString();2025-11-05- 近日,研究人员发现有超过7亿领英用户数据在暗网出售,是领英史上最大规模的数据泄露事件。2025-11-05
解决惠普电脑常见错误问题的方法(探索惠普电脑错误提示的原因与解决方案)
摘要:在日常使用电脑的过程中,我们经常会遇到各种错误提示,尤其是惠普电脑。这些错误提示不仅影响了我们的正常使用,还可能导致数据丢失和系统崩溃。为了帮助大家解决这些问题,本文将介绍一些常见...2025-11-05如何使用UnhookMe分析恶意软件中未受监控的系统调用问题
复制gitclonehttps://github.com/mgeeky/UnhookMe.git 1.2025-11-05

最新评论