我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL中怎么对数据表进行故障检测

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL中怎么对数据表进行故障检测

MySQL中怎么对数据表进行故障检测,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

表的故障检测和修正的一般过程如下:

◆ 检查出错的表。如果该表检查通过,则完成任务,否则必须修复出错的数据库表。

◆ 在开始修复之前对表文件进行拷贝,以保证数据的安全。

◆ 开始修复数据库表。

◆ 如果修复失败,从数据库的备份或更新日志中恢复数据。
在使用myisamchk或isamchk检查或修复表之前,应该首先注意:

◆ 建立数据库备份和使用更新日志,以防修复失败,丢失数据。

◆ 仔细阅读本章内容以后再进行操作,尤其是不应该在阅读“避免与MySQL服务器交互作用”之前进行操作。因为,在你没有足够的知识之前贸然操作,可能会引起严重的后果。

◆ 如果你在Unix平台上对表进行维护时,应该首先注册到专用的帐户 mysql,以避免对表读写访问产生所有权的问题,以及破坏数据库目录的所有权限。

数据库表的维护工具

MySQL的myisanchk和isamchk实用程序很类似,基本上它们具有同样的使用方法。它们之间的主要区别时所使用的表的类型。为了检查 /修复MyISAM表(.MYI和.MYD),你应该使用myisamchk实用程序。为了检查/修复ISAM表(.ISM和.ISD),你应该使用 isamchk实用程序。

◆ 为了使用任一个使用程序,应指明你要检查或修复的表,myisamchk和isamchk的使用方法为:


shell>myisamchk options tbl_nameshell>isamchk options tbl_name


如果你愿意,你可以在命令行命名几个表。

◆ 你也能指定一个名字作为一个索引文件(用“ .MYI”或“.ISM”后缀),它允许你通过使用模式“*.MYI”或“.ISM”指定在一个目录所有的表。例如,如果你在一个数据库目录,你可以这样在目录下检查所有的表:


shell> myisamchk *.MYIshell>isamchk *.ISM


◆ 如果你不在数据库目录下,你可指定目录的路径:


shell> myisamchk options /path/to/database_dir*.MYIshell> isamchk options /path/to/database_dir/*/*.ISM


这个方法无法在平台下使用。

注意  不论是myisamchk还是isamchk都不对表所在的位置做任何判断,因此,应该或者在包含表文件的目录运行程序,或者指定表的路径名。这允许你将表文件拷贝到另一个目录中并用该拷贝进行操作。

检查表

myisamchk和isamchk提供了表的检查方法,这些方法在彻底检查表的程度方面有差异。

标准的方法检查表

通常用标准的方法就足够了。对表使用标准的方法进行检查,不使用任何选项直接调用即可,或用-s或--silent选项的任何一个:


myisamchk tbl_nameisamchk tbl_name


这能找出所有错误的99.99%。它不能找出的是仅仅涉及数据文件的损坏(这很不常见)。

完全彻底的数据检查

为了执行扩充检查,使用--extend-check或-e选项,这个选项检查数据:


myisamchk -e tbl_nameisamchk -e tbl_name


它做一个完全彻底的数据检查(-e意思是“扩展检查”)。它对每一行做每个键的读检查以证实他们确实指向正确的行。这在一个有很多键的大表上可能花很长时间。myisamchk通常将在它发现第一个错误以后停止。如果你想要获得更多的信息,你能增加--verbose(-v)选项。这使得 myisamchk或isamchk继续一直到最多20个错误。在一般使用中,一个简单的标准检查(没有除表名以外的参数)就足够了。

中等程度的检查

指定选项--medium-check或-m


myisamchk -m tbl_name


中等程度的检查不如扩展检查彻底,但速度快一些。其意义不大,较少使用。

如果对于--extend-check检查不报告错误,则可以肯定表是完好的。如果你仍然感觉表有问题,那原因肯定在其它地方。应重新检查人和好像有问题的查询以验证查询是正确书写的。如果你认为问题可能是MySQL服务器的原因,应该考虑整理一份故障报告或者升级到新的版本上。
可能有用的检查选项:

1.-i或—information 打印统计信息,例如:


myisamchk -e -i tbl_name


象前面的命令一样,但是-i选项告诉myisamchk还打印出一些统计信息。

2.-C, --check-only-changed

只检查上一次检查后被修改的表

看完上述内容,你们掌握MySQL中怎么对数据表进行故障检测的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL中怎么对数据表进行故障检测

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

怎么对Python数据表进行检查

这期内容当中小编将会给大家带来有关怎么对Python数据表进行检查,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。python的五大特点是什么python的五大特点:1.简单易学,开发程序时,专注的是解决问
2023-06-14

Cassandra中怎么进行故障检测和恢复

Cassandra中的故障检测和恢复是由系统自动处理的,主要通过以下方式进行:Gossip协议:Cassandra使用Gossip协议来维护节点之间的通信和协调。节点会周期性地向其他节点发送心跳信息,以确保它们之间的连接正常。如果节点发现某
Cassandra中怎么进行故障检测和恢复
2024-04-09

mysql中怎么对数据进行排序

在MySQL中,可以使用ORDER BY子句对数据进行排序。语法如下:SELECT * FROM table_name ORDER BY column_name [ASC|DESC];其中,SELECT *表示选择所有列,table_
mysql中怎么对数据进行排序
2024-04-09

怎么在MySQL中分表分库时对数据进行切分

今天就跟大家聊聊有关怎么在MySQL中分表分库时对数据进行切分,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。数据库分布式核心内容无非就是数据切分(Sharding)以及切分后对数据的
2023-06-14

MySQL中怎么对表格进行排序

在MySQL中,可以使用ORDER BY子句对表格进行排序。例如,要按照某个列的值对表格进行升序排序,可以使用以下语法:SELECT * FROM table_name ORDER BY column_name ASC;要按照某个列的值对
MySQL中怎么对表格进行排序
2024-04-09

Go怎么对数据库CRUD进行Mock测试

今天小编给大家分享一下Go怎么对数据库CRUD进行Mock测试的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。go-sqlmo
2023-07-02

layui怎么对列表数据进行筛选

在Layui中,可以使用table模块的filter()方法对列表数据进行筛选。具体步骤如下:1. 在HTML中定义一个表格,并为每一行添加一个class属性,用于标识每一行的数据。```html姓名年龄性别张三18男李四20女王五22男`
2023-09-22

MySQL中怎么对数组类型数据进行操作

在MySQL中,并没有直接支持数组类型数据的操作,但可以通过其他方式来模拟数组类型数据的操作,比如使用JSON数据类型或者使用多对多关系来表示数组。1、使用JSON数据类型:可以将数组数据存储在JSON格式的字段中,然后使用JSON函数来
MySQL中怎么对数组类型数据进行操作
2024-04-30

ABAP工作进程对数据库表读取操作的检测是怎样的

本篇文章给大家分享的是有关ABAP工作进程对数据库表读取操作的检测是怎样的,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。小编要介绍的,是使用SM50检测出工作进程长时间读取一张
2023-06-03

GitLab中怎么对数据进行备份

这篇文章主要讲解了“GitLab中怎么对数据进行备份”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“GitLab中怎么对数据进行备份”吧!1,全备份集成包安装:# gitlab-rake gi
2023-06-28

使用python怎么对表格数据进行处理

这篇文章给大家介绍使用python怎么对表格数据进行处理,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。python对Excel表格的处理首先我们看一个最简单的情况,我们先不考虑性能的问题,那么我们可以使用xlrd这个工
2023-06-14

MySQL 分表分库怎么进行数据切分

关系型数据库本身比较容易成为系统瓶颈,单机存储容量、连接数、处理能力都有限。当单表的数据量达到1000W或100G以后,由于查询维度较多,即使添加从库、优化索引,做很多操作时性能仍下降严重。此时就要考虑对其进行切分了,切分的目的就在于减少数
2022-05-23

编程热搜

目录