百木园-与人分享,
就是让自己快乐。

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

image-20230105161905827

技术交流群:

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

image-20221030163217640


来源:https://www.cnblogs.com/greatsql/p/17271395.html
本站部分图文来源于网络,如有侵权请联系删除。

未经允许不得转载:百木园 » MySQL 8.0数据字典有什么变化

相关推荐

  • 暂无文章