翼度科技»论坛 编程开发 mysql 查看内容

MySQL 8.0数据字典有什么变化

11

主题

11

帖子

33

积分

新手上路

Rank: 1

积分
33

  • GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源。
  • GreatSQL是MySQL的国产分支版本,使用上与MySQL一致。
  • 作者: 叶金荣
  • 文章来源:GreatSQL社区原创
1. MySQL 8.0数据字典有什么变化

从MySQL 8.0开始,采用独立表空间模式的每个InnoDB表只有一个 .ibd 表空间文件,而不再有 .frm 文件了。为了实现DDL的原子性,InnoDB直接把元数据存储在表空间文件中,需要的话,可是使用 ibd2sdi 工具从中读取,例如:
  1. $ ibd2sdi test/t1.sdi
  2. ["ibd2sdi"
  3. ,
  4. {
  5.         "type": 1,
  6.         "id": 1268,
  7.         "object":
  8.                 {
  9.     "mysqld_version_id": 80031,
  10.     "dd_version": 80023,
  11.     "sdi_version": 80019,
  12.     "dd_object_type": "Table",
  13. ...
  14. {
  15.         "type": 2,
  16.         "id": 29,
  17.         "object":
  18.                 {
  19.     "mysqld_version_id": 80031,
  20.     "dd_version": 80023,
  21.     "sdi_version": 80019,
  22.     "dd_object_type": "Tablespace",
  23.     "dd_object": {
  24.         "name": "test/t1",
  25.         "comment": "",
  26.         "options": "autoextend_size=0;encryption=N;",
  27.         "se_private_data": "flags=16417;id=24;server_version=80031;space_version=1;state=normal;",
  28.         "engine": "InnoDB",
  29.         "engine_attribute": "",
  30.         "files": [
  31.             {
  32.                 "ordinal_position": 1,
  33.                 "filename": "./test/t1.ibd",
  34.                 "se_private_data": "id=24;"
  35.             }
  36.         ]
  37.     }
  38. }
  39. }
  40. ]
复制代码
如果是MyISAM引擎表,也不再有 .frm文件,而是采用 .sdi 文件来记录元数据信息。
在 .sdi 文件中,采用JSON格式存储元数据信息。
对于MyISAM表,不能再像以前那样,直接把 .frm.MYD.MYI 文件拷贝到目标数据库后就能直接用。方法改成了类似下面这样的:
  1. # 首先拷贝数据及索引文件到目标数据库
  2. $ cp -p ./db1/t1.MYD ./db1/t1.MYI ./db2
  3. # 拷贝 .sdi 文件到 secure_file_priv 指定的路径下
  4. $ cp -p ./db1/t1_1274.sdi $secure_file_priv/
  5. # 修改 .sdi 文件中的 schema 值,将 db1 改成 db2
  6. # MySQL文档中没提到这点,但实测过程中发现需要加这步操作
  7. $ vim $secure_file_priv/t1_1274.sdi
  8. ...
  9. "schema_ref":"db1"  #此处修改成 "schema_ref":"db2"
  10. ...
  11. # 执行导入操作
  12. 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 即可
  1. select * from variables_by_thread where VARIABLE_NAME = 'sort_buffer_size';
  2. +-----------+------------------+----------------+
  3. | THREAD_ID | VARIABLE_NAME    | VARIABLE_VALUE |
  4. +-----------+------------------+----------------+
  5. |     29310 | sort_buffer_size | 4194304        |
  6. |     29375 | sort_buffer_size | 4194304        |
  7. |     29378 | sort_buffer_size | 32768          |  -- 在这个session里修改成其他非默认设置值
  8. |     29209 | sort_buffer_size | 4194304        |
  9. +-----------+------------------+----------------+
复制代码
再根据 THREAD_ID 列和 performance_schema.threads 关联查询,即可知道每个/某个session里的variables是否有自定义设置了。
3. mysqlpump备份并不好用

用mysqlpump备份时,默认是不会备份用户授权信息的,需要类似这样 mysqlpump --exclude-databases=% --users 单独指定选项才能额外备份用户授权信息。

Enjoy GreatSQL
来源:https://www.cnblogs.com/greatsql/p/17271395.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

上一篇: MySQL存储过程

下一篇: mysqldump详解

举报 回复 使用道具