MYSQL教程:检查数据表和修复数据表

作者:佚名 来源:网页教学网 时间:2009-03-11 15:24:00 

数据库在运行中,会因为人为因素或一些不可抗力因素造成数据损坏。所以为了保护数据的安全和最小停机时间,我们需制定详细的备份/恢复计划,并定期对计划的有效性进行测试。

本章结合MySQL服务器的运行机制和所提供的工具,介绍如何进行数据库的备份、维护和修复。

以下是几点防范的措施:

制定一份数据库备份/恢复计划,并对计划进行仔细测试。

启动数据库服务器的二进制变更日志,该功能的系统开销很小(约为1%),我们没有理由不这样做。

定期检查数据表,防范于未燃。

定期对备份文件进行备份,以防备份文件失效。

把MySQL的数据目录和备份文件分别放到两个不同的驱动器中,以平衡磁盘I/O和增加数据的安全。

检查/修复数据表
对数据表进行维护最好通过发出CHECK TABLE(检查数据表)或REPAIRE TABLE(修复数据表)命令来做,这样MySQL服务器自动进行表锁定以协调数据表中数据的读写一致性问题。

也可用myisamchk工具来做数据表的维护,但它直接访问有关的数据表文件,不通过服务器,所以需人为地协调数据表数据的读写一致性问题。使用myisamchk检查数据表的具体操作步骤如下:

以mysql客户端程序连接服务器,并发出LOCK TABLE命令,以只读方式锁住数据表。

% mysql

mysql> use db

mysql> LOCK TABLE table_name READ;     #以只读方式锁定表

mysql> FLUSH TABLE table_name;        #关闭数据表文件,并把内存中的信息写入磁盘

保持上面的状态不退出,另开一个shell窗口,用以下命令维护(检查)数据表。

% myisamchk table_name
   
如果不保持上面状态,退出mysql会话,则表锁定会自动取消。

维护完成,切换回mysql状态的shell窗口,发出以下命令解除表锁定。

mysql> UNLOCK TABLES;

使用myisamchk修复数据表的具体操作步骤如下:

进行修复操作需以读/写方式锁定数据表,命令如下:

% mysql

mysql> use db

mysql> LOCK TABLE table_name WRITE;     #以读/写方式锁定数据表

mysql> FLUSH TABLE table_name;

保持mysql客户端连接状态,切换到第二个shell窗口,运行修复命令:

% myisamchk --recover table_name
   
运行修复命令前最好先备份一下数据文件。

修复完成后,切换回mysql客户端连接窗口,运行以下命令解除数据表锁定:

mysql> FLUSH TABLE table_name;     #使服务器觉察新产生的索引文件

mysql> UNLOCK TABLE;

还可用以下命令锁定所有表,锁定后,所有用户就只能读不能写数据,这样就可使我们能安全地拷贝数据文件。

mysql> FLUSH TABLES WITH READ LOCK;

下面是解除锁语句:

mysql> UNLOCK TABLES;

标签:MYSQL,检查数据,修复,数据表
0
投稿

猜你喜欢

  • 清除代码异味

    2011-05-21 08:34:00
  • Dreamweaver实现flash透明背景

    2008-05-04 09:35:00
  • HTML,CSS和JavaScript速查表

    2010-09-16 13:02:00
  • 用javascript实现select的美化

    2007-05-11 16:50:00
  • MS IIS server Frontpage Ext Server漏洞

    2008-05-04 09:54:00
  • 如何上传一个.SQL文件到远程主机并且执行它来部署一个SQL数据库

    2007-09-23 13:03:00
  • document.createElement()用法及注意事项

    2008-04-21 15:16:00
  • 用css+Javascript实现扫描线效果图片

    2007-11-08 19:12:00
  • ASP程序种如何调用DLL文件

    2008-01-15 19:12:00
  • 修改、删除数据记录(DELETE\\UPDATE)

    2009-02-27 15:50:00
  • 由浅入深讲解MySQL数据库索引的选择性

    2008-12-17 15:06:00
  • 按钮表状态还是表动作?

    2009-03-23 18:21:00
  • 把网页中的(电话,qq等数字)生成图片的ASP程序

    2011-04-11 10:40:00
  • SNS用户体验和互动性浅析

    2011-01-17 17:56:00
  • [译]Javascript风格要素(二)

    2008-02-29 12:51:00
  • 30万条数据,搜索文本字段的各种方式对比

    2010-05-02 10:17:00
  • 您需要了解的DIV+CSS网页布局的8条面试题目

    2010-01-29 13:22:00
  • 如何获取机器的网络配置属性?

    2009-11-23 20:44:00
  • rs.getrows的使用方法

    2008-04-05 14:01:00
  • Web标准基础教程:CSS简写指南

    2010-04-02 12:47:00
  • asp之家 网络编程 m.aspxhome.com