乐趣区

关于数据库:MySQL-80数据字典有什么变化

  • 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

技术交换群:

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

退出移动版