天天在用钱

迁移数据常用

1、导出文件 - mysqldump 命令

‍mysqldump 是 Mysql 自带的逻辑备份工具。其备份原理是通过协议连接到 Mysql 数据库,将需要备份的数据查询出来转换成对应的 insert 语句。当需要还原这些数据时,只要执行这些 insert 语句,即可将对应的数据还原。

常用命令:

  • 导出所有数据库
mysqldump -uroot -p123456 --all-databases  >/tmp/all.sql
  • 导出指定数据库
mysqldump -uroot -p123456 --databases  db  >/tmp/db.sql
  • 导出指定表
mysqldump -uroot -p123456 --databases  db  --tables a >/tmp/a.sql
  • 根据条件导出数据
mysqldump -uroot -p123456 --databases db --tables a --where='id=1' >/tmp/a.sql
  • 指导出表结构
mysqldump -uroot -p123456 --no-data --databases db  >/tmp/db.sql

2、导入文件 - source 命令

source 命令可以将导出的 sql 文件导入进指定数据库。

操作步骤:

  • use 数据库;
  • soucre 已导出的 sql 文件。

迁移思路

1. 数据库A历史数据迁移到 hdfs(一种分布式文件系统)上进行归档;

2. 删除数据库A已归档的表,使用 drop 命令;

3. 数据库A上新建表,用于数据库B迁移;

4. 数据库B中除未完成单外都迁移至数据库A;

5. 脚本进行删除数据库B上已迁移数据。

阿丁开讲

1、参数介绍

在 Innodb 存储引擎中,innodb_file_per_table 参数是用来控制表数据的存储方式的。

当参数为 OFF 的时候,所有数据都存放于默认路径下名为 ibdata* 的共享表空间里,即将数据库所有的表数据及索引文件存放到一个文件中。在删除数据表的时候,ibdata* 文件不会自动收缩。

当参数为 ON 的时候,每一个表都将存储在一个以 .ibd 为后缀的文件中。这样每个表都有了自己独立的表空间,通过 drop table 命令就可以将表空间进行回收。

从 Mysql 5.6.6 版本开始,innodb_file_per_table 默认为 ON 状态。

2、参数设置

通过 show variables like '%per_table%' 命令,可以查看 innodb_file_per_table 参数的当前状态:

如果想修改参数的状态,可通过 SET GLOBAL 动态地修改为 ON 或 OFF,也可以在 my.cnf 中做永久性修改。需要注意的是,在 my.cnf 中修改后生效的话需要重启 mysqld 服务。

疑问:如果之前参数为 OFF 状态,设置为 ON 状态后,表空间如何分配?

答案是仅对后续操作生效。

什么意思呢?修改前的数据还维持原状,也就是说之前的数据继续存放于 ibdata* 文件中,修改后可使用独立表空间。

所以建议在开始就将该参数设置为 ON 状态。

第二天

阿丁二次开讲

在这之前要先介绍下 Innodb 存储数据所用的 B+ 树结构,画个图你理解下:

在图中,P 代表一页数据,R 代表一行数据。

假设我们要删掉 R2 这条记录,InnoDB 引擎只会将其标记为删除状态,并不会真正把这行数据所占的空间释放掉,也就是说这个坑位还留着。如果后续所插入的数据在 R1 与 R3 之间的话,这个空间是可以被使用上的。

假设我们恰好删除了 R1、R2、R3 这三条记录,也就是说 P1 这一页的数据都被删掉了,那么 P1 所在的空间都会被标记为可复用。如果插入的数据需要使用新页的话,P1 的坑位就可以被利用起来了。

那么你可能会问了,我插入的数据恰好巧妙的避开了这些位置呢。那我还能说啥,骚呗。这样会造成很多空间被浪费,如果删除大量的数据的话,被浪费的空间也会是巨大的。

optimize table 的本质是 ALTER TABLE xxx ENGINE = InnoDB;

在5.5版本之前,重建表的过程是这样的:

然后用临时文件替换旧表,这样便实现了表的重建。

注意

1、控制迁移速度,防止主从延迟导致线上故障;

2、创建大表时,使用下面的建表语句可节省 50% 左右的空间:

ROW_FORMAT=COMPRESSED KEY_BLOCK_SIZE=8

3、使用 optimize table 压缩表时,需要留够一定的空间。

mysqld已删除但仍占用空间的_活见鬼,明明删除了数据,空间却没减少相关推荐

  1. mysql 删除数据 降低_活见鬼,明明删除了数据,空间却没减少!

    原标题:活见鬼,明明删除了数据,空间却没减少! 作者 |莱乌 来源 |IT界农民工 迁移数据常用 1.导出文件 -mysqldump 命令 ‍mysqldump‍是 Mysql 自带的逻辑备份工具.其 ...

  2. diskgenius 数据迁移_活见鬼,明明删除了数据,空间却没减少! - *IT界农民工*

    迁移数据常用 1.导出文件 - mysqldump 命令  ‍mysqldump 是 Mysql 自带的逻辑备份工具.其备份原理是通过协议连接到 Mysql 数据库,将需要备份的数据查询出来转换成对应 ...

  3. mysqld已删除但仍占用空间的_U盘删除的文件在哪?

    U盘作为最常用的移动存储设备,几乎是办公必备的单品. 电脑文件删除了还能在回收站中找回,U盘删除的文件就不一样了,它不在回收站里.如何找回U盘删除的文件,下面小编就给大家讲解一下. 百度经验-U盘文件 ...

  4. matlab怎么删除上一条命令_怎么恢复电脑上删除的图片?四大步搞定

    怎么恢复电脑上删除的图片?在使用电脑的时候,经常会为了使电脑的运行速率增强,会定期对电脑上存储的文件进行清理.但是在清理文件的时候,问题也就随之产生了!比方说:电脑上存储的图片被删除了.那么,如果遇到 ...

  5. mysqld已删除但仍占用空间的_Windows 10删除备份文件方法

    Windows具有许多内置备份功能,包括卷影副本,系统还原点和整个系统备份.尽管它们既不是最可靠也不是功能最丰富的备份解决方案,但它们确实提供了一种备份系统和个人数据的不错的方式. Windows内置 ...

  6. sqlsugar 批量删除guid类型主键_一文上手SqlSugar 「C# 数据操作系列」

    0. 前言 前言,暂时挥别NHibernate(虽然我突然发现这玩意还挺有意思的,不过看得人不多).大步进入了有很多小伙伴向我安利的SQLSugar,嗯,我一直叫SugarSQL,好像是这个吧? 这是 ...

  7. rman删除7天前备份_干货分享|DM7如何删除7天前的备份文件

    DM7如何删除7天前的备份文件 背景 生产系统中由于数据量较大,备份文件较多,存储空间很快就撑满,隔几天就要清理一次备份文件,为了更好的解决此问题,提供如下解决办法. 处理DM管理工具 说明:达梦安装 ...

  8. 活见鬼,明明删除了数据,空间却没减少!

    迁移数据常用 1.导出文件 - mysqldump 命令 ‍mysqldump ‍是 Mysql 自带的逻辑备份工具.其备份原理是通过协议连接到 Mysql 数据库,将需要备份的数据查询出来转换成对应 ...

  9. 3皮卡丘眨眼代码_活见久,皮卡丘居然是一门编程语言

    我很荣幸地向你介绍皮卡神教的编程语言,这门语言专为皮神设计(认真脸).为什么一定要学习这门语言呢--谁不想要只皮卡丘我问你? 在当今的宝可梦就业环境中,大多数皮卡丘们都在残忍的宝可梦训练师手下过着顺从 ...

  10. 2023年最新批量删除微博_新版微博怎么批量删除自己发的微博?

    2023批量删除微博插件小工具_微博如何一次性批量删除微博 一千多条微博怎么删?微博怎么批量删除_怎样把发的微博全删了 视频如下 2022最新批量删除微博丨怎么一键批量删除微博与删除关注? 目前微博不 ...

最新文章

  1. vue 发展历程时间轴动画_PPT时间轴如何做出创意感?海量素材免费分享,网友:收藏...
  2. LSM树——放弃读能力换取写能力,将多次修改放在内存中形成有序树再统一写入磁盘,查找复杂度O(k*log(n)),结合bloom filter提高查找性能...
  3. angular2、ng2 http get post 传参
  4. yolo人脸检测数据集_自定义数据集上的Yolo-V5对象检测
  5. 蓝桥杯小朋友排队java_[蓝桥杯][历届试题]小朋友排队 (C++代码)
  6. HDR高动态压缩【MATLAB代码】
  7. LeetCode003-无重复字符的最长子串(Length of longest substring)-Rust语言实现
  8. 笔记56 | 管理网络的使用
  9. MySQL 主主同步配置和主从配置步骤
  10. 2013年计算机试题(四),2013年计算机一级考试试题(精简版):第四套
  11. 飞思卡尔c语言,飞思卡尔MCU的C语言编程框架
  12. 《产品经理的第一本书》--产品经理职责
  13. 教师计算机知识培训内容,新学期教师计算机培训方案
  14. 【博客5】缤果LabView串口调试助手V2.0 (高级篇)
  15. 学习笔记(8):ArcGIS10.X入门实战视频教程(GIS思维)-矢量数据数量分级显示、图表显示,多属性、lyr保存
  16. CodeForces 332B Maximum Absurdity
  17. 哪个直播平台更适合做企业会议直播?
  18. AirDisk存宝 【S3和S6后面的USB口是用来干嘛的?有什么作用?】
  19. html中符号向下箭头号,html箭头相关符号
  20. java web孤傲苍狼,JavaWeb学习笔记

热门文章

  1. net异步线程获取返回值的三种方式
  2. CSS3 Transform——transform-origin
  3. 生成随机不重复数列表(C#)
  4. Appcan将支持在线编译提交App Store
  5. python之scipy
  6. 20200706每日一句
  7. 七月算法机器学习4 凸优化初步
  8. Atitit.自定义存储引擎的接口设计 api 标准化 attilax 总结  mysql
  9. paip.提升用户体验----记住用户名与自动登录
  10. 问一个 TCP 连接可以发多少个 HTTP 请求?