Login
网站首页 > 文章中心 > 其它

MySQL 8.0数据字典有什么变化

作者:小编 更新时间:2023-09-16 07:32:16 浏览量:259人看过

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

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


$ 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_127④sdi $secure_file_priv/

# 修改 .sdi 文件中的 schema 值,将 db1 改成 db2
# MySQL文档中没提到这点,但实测过程中发现需要加这步操作
$ vim $secure_file_priv/t1_127④sdi
...
"schema_ref":"db1"  #此处修改成 "schema_ref":"db2"
...

# 执行导入操作
mysql> IMPORT TABLE FROM '$secure_file_priv/t1_127④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是否有自定义设置了.

用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

MySQL ⑧0数据字典有什么变化

技术交流群:

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

MySQL ⑧0数据字典有什么变化

以上就是土嘎嘎小编大虾米为大家整理的相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!

版权声明:倡导尊重与保护知识产权。未经许可,任何人不得复制、转载、或以其他方式使用本站《原创》内容,违者将追究其法律责任。本站文章内容,部分图片来源于网络,如有侵权,请联系我们修改或者删除处理。

编辑推荐

热门文章