• 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社区:

MySQL 8.0数据字典有什么变化

社区有奖建议反馈: greatsql.cn/thread-54-1…

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

社区2022年度勋章获奖名单: greatsql.cn/thread-184-…

(对文章有疑问或许有独到见解都可以去社区官网提出或共享哦~)

技术交流群:

微信&QQ群:

QQ群:533341697

微信群:增加GreatSQL社区助手(微信号:wanlidbc )好友,待社区助手拉您进群。