MySQL 8.0数据字典有什么变化

yizhihongxing
  • 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数据字典有什么变化 - Python技术站

(0)
上一篇 2023年4月18日
下一篇 2023年4月18日

相关文章

  • MySQL 并行复制方案演进历史及原理分析

    预告: 《MySQL实战》即将出版,敬请关注! 有过线上 MySQL 维护经验的童鞋都知道,主从延迟往往是一个让人头疼不已的问题。 不仅仅是其造成的潜在问题比较严重,而且主从延迟原因的定位尤其考量 DBA 的综合能力:既要熟悉复制的内部原理,又能解读主机层面的资源使用情况,甚至还要会分析 binlog。 导致主从延迟的一个常见原因是,对于 binlog 中的…

    MySQL 2023年4月11日
    00
  • mysql的数据压缩性能对比详情

    下面是关于“MySQL的数据压缩性能对比详情”的完整攻略。 问题提出 MySQL在数据存储方面可以采取压缩方式,以减小数据存储空间和提高查询效率。但是,各种压缩方式之间的性能和压缩比例有何差异?如何选择合适的压缩方式? 调研过程 实验方案 为了找到一种实用而又合适的压缩方式,我们对比了MySQL常见的3中压缩方式(MyISAM、InnoDB和TokuDB)。…

    MySQL 2023年5月19日
    00
  • MySQL的join buffer原理

    MySQL中的join buffer是一种缓存机制,用于优化数据的连接查询。在执行连接查询的过程中,MySQL需要将多个表的数据进行连接匹配,这个过程是比较耗时的。而使用join buffer缓存机制,则可以提高连接查询的效率。 join buffer的原理比较简单,它会将连接操作中的数据缓存在内存中,以便在下一次进行相同的查询时可以直接从缓存中获取数据,而…

    MySQL 2023年5月19日
    00
  • 详解MySQL InnoDB的索引扩展

    MySQL InnoDB索引扩展详解 InnoDB是MySQL中,一个常用的事务性存储引擎,也是MySQL5.5版本以后默认的存储引擎。InnoDB对于数据的存储以及索引都有自己的特定优化策略,本文主要探讨InnoDB在索引扩展上的优化方式。 InnoDB的索引类型 InnoDB支持B-Tree索引(默认)、全文索引,以及R-Tree索引和哈希索引。 B-T…

    MySQL 2023年5月19日
    00
  • MySQL 5.7 学习心得之安全相关特性

    MySQL 5.7 学习心得之安全相关特性 MySQL是非常流行的数据库管理系统,但是随着互联网的发展,数据库安全问题也越来越受到关注。MySQL 5.7发布了一些新的安全特性,来保护数据库的安全性。 密码管理 MySQL 5.7在密码管理方面做出了一些改进。现在MySQL强制要求用户在新建用户时,必须指定一个密码。同时还提供了密码复杂度检查功能。 示例1 …

    MySQL 2023年5月18日
    00
  • Ubuntu下启动、停止、重启MySQL,查看错误日志命令大全

    针对Ubuntu下启动、停止、重启MySQL,查看错误日志命令,我为您提供以下攻略。 启动MySQL服务 要启动MySQL服务,可以通过以下命令: sudo service mysql start 示例说明:假设您的MySQL服务在Ubuntu系统中已经安装并且配置好了,这条命令可以启动MySQL服务。您可以在终端中输入以上命令来启动MySQL服务。 停止M…

    MySQL 2023年5月18日
    00
  • MySQL8.0.11版本的新增特性介绍

    MySQL 8.0.11版本的新增特性介绍 MySQL 8.0.11 是 MySQL 数据库管理系统的一个版本,于2018年4月发布。本次更新主要强调了MySQL在安全性和性能方面的提升。以下是MySQL 8.0.11版本的新增特性介绍。 数据字典 MySQL 8.0.11版本开始支持“数据字典”功能。这一新特性将原本的系统表移到了MySQL中的一个新Sch…

    MySQL 2023年5月19日
    00
  • ☆常用的Sql语句汇总(DDL/DML)

    常用的sql语句汇总 1、获取所有表名、表信息 里面有表注释 数据库种类 sql 备注 mysql — 获取所有表名、视图名show tables– 获取 dev_test_data数据库 所有表、视图信息select * from information_schema.tables where table_schema=’dev_test_data’-…

    MySQL 2023年5月6日
    00
合作推广
合作推广
分享本页
返回顶部