1. MySQL 8.0数据字典有什么变化
从MySQL 8.0开始,采用独立表空间模式的每个InnoDB表只有一个 .ibd 表空间文件,而不再有 .frm 文件了。为了实现DDL的原子性,InnoDB直接把元数据存储在表空间文件中,需要的话,可是使用 ibd2sdi 工具从中读取,例如:
如果是MyISAM引擎表,也不再有 .frm文件,而是采用 .sdi 文件来记录元数据信息。
在 .sdi 文件中,采用JSON格式存储元数据信息。
对于MyISAM表,不能再像以前那样,直接把 .frm.MYD.MYI 文件拷贝到目标数据库后就能直接用。方法改成了类似下面这样的:
上文中的 $secure_file_priv 需要自行替换成实际路径。
另外,.sdi 文件名前面的数字,是该表的隐藏ID,每次新建一个表,这个值都会顺序增加,类似 InnoDB 表的 TABLE_ID 值(这里说的是类似,二者不等价)。
2. 怎么查看每个/某个session里设置的variables
查看 performance_schema.variables_by_thread 即可
再根据 THREAD_ID 列和 performance_schema.threads 关联查询,即可知道每个/某个session里的variables是否有自定义设置了。
3. mysqlpump备份并不好用
用mysqlpump备份时,默认是不会备份用户授权信息的,需要类似这样 mysqlpump –exclude-databases=% –users 单独指定选项才能额外备份用户授权信息。
评论已关闭