最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

如何回收mysql表的碎片

来源:动视网 责编:小采 时间:2020-11-09 13:55:46
文档

如何回收mysql表的碎片

如何回收mysql表的碎片:由于操作人员大量的删除了relationship表的数据达2千万行,但是mysql并不自动回收空间,所以决定做碎片整理(先测试): myisamchk -r relationship 在mysql运行下做的,结果做完后查询的时候出现下面的问题: ERROR 1030 (00000): Got
推荐度:
导读如何回收mysql表的碎片:由于操作人员大量的删除了relationship表的数据达2千万行,但是mysql并不自动回收空间,所以决定做碎片整理(先测试): myisamchk -r relationship 在mysql运行下做的,结果做完后查询的时候出现下面的问题: ERROR 1030 (00000): Got


由于操作人员大量的删除了relationship表的数据达2千万行,但是mysql并不自动回收空间,所以决定做碎片整理(先测试): myisamchk -r relationship 在mysql运行下做的,结果做完后查询的时候出现下面的问题: ERROR 1030 (00000): Got error 127 from table h

  由于操作人员大量的删除了relationship表的数据达2千万行,但是mysql并不自动回收空间,所以决定做碎片整理(先测试):

  myisamchk -r relationship

  在mysql运行下做的,结果做完后查询的时候出现下面的问题:

  ERROR 1030 (00000): Got error 127 from table handler

  这个问题很郁闷,应该不会出现问题的呀,后来查阅资料发现了问题:

  如果你用--skip-locking运行mysqld(它在一些系统上是缺省的,如Linux),当

  mysqld正在使用同一个表时,你不能可靠地使用myisamchk检查一张表。如果你能

  肯定在你运行myisamchk时没有人通过mysqld正在存取表,在你开始检查表之前,

  你仅需做mysqladmin flush-tables。如果你不能保证, 那么当你检查表时,你必

  须停掉mysqld。如果你在mysqld正在更新表时运行myisamchk,你可能得到一个表

  已破坏的警告,即使它没有。

  如果你没使用--skip-locking,你能在任何时间使用myisamchk检查表。当你这样

  时,所有试图更新表的客户在继续前将等到myisamchk就绪。

  如果你使用myisamchk修复或优化表,你必须总是保证mysqld服务器不在使用表(如

  果你正在使用--skip-locking,这也适用)。如果你不停掉mysqld,在你运行

  myisamchk前,你至少应该做一个mysqladmin flush-tables。

  而我的数据库恰好在linux下,并且是skip-locking启动的,就出现了这个问题!

  1)这个命令也可以停止mysql后再做,,就不会出现这个问题

  2)也可以在线做后重启数据库

  3)也可以先运行mysqladmin flush-tables后再执行这个命令,也不会出现这个问题!

文档

如何回收mysql表的碎片

如何回收mysql表的碎片:由于操作人员大量的删除了relationship表的数据达2千万行,但是mysql并不自动回收空间,所以决定做碎片整理(先测试): myisamchk -r relationship 在mysql运行下做的,结果做完后查询的时候出现下面的问题: ERROR 1030 (00000): Got
推荐度:
标签: 数据 如何 碎片
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top