mysql isamchk_MySQL之myisamchk

2023-11-03

Description, check and repair of MyISAM tables.

Used without options all tables on the command will be checked for errors

Usage: myisamchk [OPTIONS] tables[.MYI]

Global options:

-H, --HELP Display this help and exit.

-?, --help Display this help and exit.

-O, --set-variable var=option.

Change the value of a variable. Please note that

this option is deprecated; you can set variables

directly with '--variable-name=value'.

-t, --tmpdir=path Path for temporary files. Multiple paths can be

specified, separated by colon (:), they will be used

in a round-robin fashion.

-s, --silent Only print errors. One can use two -s to make

myisamchk very silent.

-v, --verbose Print more information. This can be used with

--description and --check. Use many -v for more verbosity.

-V, --version Print version and exit.

-w, --wait Wait if table is locked.

Check options (check is the default action for myisamchk):

-c, --check Check table for errors.

-e, --extend-check Check the table VERY throughly. Only use this in

extreme cases as myisamchk should normally be able to

find out if the table is ok even without this switch.

-F, --fast Check only tables that haven't been closed properly.

-C, --check-only-changed

Check only tables that have changed since last check.

-f, --force Restart with '-r' if there are any errors in the table.

States will be updated as with '--update-state'.

-i, --information Print statistics information about table that is checked.

-m, --medium-check Faster than extend-check, but only finds 99.99% of

all errors. Should be good enough for most cases.

-U --update-state Mark tables as crashed if you find any errors.

-T, --read-only Don't mark table as checked.

Repair options (When using '-r' or '-o'):

-B, --backup Make a backup of the .MYD file as 'filename-time.BAK'.

--correct-checksum Correct checksum information for table.

-D, --data-file-length=# Max length of data file (when recreating data

file when it's full).

-e, --extend-check Try to recover every possible row from the data file

Normally this will also find a lot of garbage rows;

Don't use this option if you are not totally desperate.

-f, --force Overwrite old temporary files.

-k, --keys-used=# Tell MyISAM to update only some specific keys. # is a

bit mask of which keys to use. This can be used to

get faster inserts.

--max-record-length=#

Skip rows bigger than this if myisamchk can't allocate

memory to hold it.

-r, --recover Can fix almost anything except unique keys that aren't

unique.

-n, --sort-recover Forces recovering with sorting even if the temporary

file would be very big.

-p, --parallel-recover

Uses the same technique as '-r' and '-n', but creates

all the keys in parallel, in different threads.

-o, --safe-recover Uses old recovery method; Slower than '-r' but can

handle a couple of cases where '-r' reports that it

can't fix the data file.

--character-sets-dir=...

Directory where character sets are.

--set-collation=name

Change the collation used by the index.

-q, --quick Faster repair by not modifying the data file.

One can give a second '-q' to force myisamchk to

modify the original datafile in case of duplicate keys.

NOTE: Tables where the data file is currupted can't be

fixed with this option.

-u, --unpack Unpack file packed with myisampack.

Other actions:

-a, --analyze Analyze distribution of keys. Will make some joins in

MySQL faster. You can check the calculated distribution

by using '--description --verbose table_name'.

--stats_method=name Specifies how index statistics collection code should

treat NULLs. Possible values of name are "nulls_unequal"

(default for 4.1/5.0), "nulls_equal" (emulate 4.0), and

"nulls_ignored".

-d, --description Prints some information about table.

-A, --set-auto-increment[=value]

Force auto_increment to start at this or higher value

If no value is given, then sets the next auto_increment

value to the highest used value for the auto key + 1.

-S, --sort-index Sort index blocks. This speeds up 'read-next' in

applications.

-R, --sort-records=#

Sort records according to an index. This makes your

data much more localized and may speed up things

(It may be VERY slow to do a sort the first time!).

-b, --block-search=#

Find a record, a block at given offset belongs to.

由于临时断电,使用kill -9中止MySQL服务进程,所有的这些都可能会毁坏MySQL的数据文件。如果在被干扰时,服务正在改变文件,文件可能会留下错误的或不一致的状态。因为这样的毁坏有时是不容易被发现的,当你发现这个错误时可能是很久以后的事了。于是,当你发现这个问题时,也许所有的备份都有同样的错误。

myisamchk通过一行一行地创建一个“.MYD”(数据 )文件的副本来工作,它通过由删除老的“.MYD 文件并且重命名新文件到原来的文件名结束修复阶段。如果你使用--quick,myisamchk不创建一个临时“.MYD”文件,只是假定“.MYD”文件是正确的并且仅创建一个新的索引文件,不接触“.MYD”文件,这是安全的,因为myisamchk自动检测“.MYD”文件是否损坏并且在这种情况下,放弃修复。你也可以给myisamchk两个--quick选项。在这种情况下,myisamchk不会在一些错误上(象重复键)放弃,相反试图通过修改“.MYD”文件解决它们。通常,只有在你在太少的空闲磁盘空间上实施一个正常修复,使用两个--quick选项才有用。在这种情况下,你应该至少在运行myisamchk前做一个备份。

1、myisamchk

使用myisamchk必须暂时停止MySQL服务器。例如,我们要检修test数据库。执行以下操作:

# service mysqld stop ;

# myisamchk -r /var/lib/mysql/test/*MYI

# service mysqld start;

myisamchk会自动检查并修复数据表中的索引错误。

2、mysqlcheck

使用mysqlcheck无需停止MySQL,可以进行热修复。

#mysqlcheck –r DBname Tablename –uuser –ppassword

注意,无论是myisamchk还是mysqlcheck,一般情况下不要使用-f强制修复,-f参数会在遇到一般修复无法成功的时候删除

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

mysql isamchk_MySQL之myisamchk 的相关文章

  • 联想笔记本电脑u盘重装win10系统教学

    联想笔记本电脑u盘重装win10系统教学 如果你有一个闲置的u盘 那么建议你可以拿它来练手一下u盘重装系统 我们只需要将这个u盘制作成为启动盘 之后有需要重装系统都可以使用它 甚至朋友有需要重装系统 也可以使用它来快速的帮忙重装一个新系统
  • 云计算概念及发展历程

    云计算概念 云计算是一种按使用量付费的模式 这种模式提供可用的 便捷的 按需的网络访问 进入可配置的计算机资源共享池 资源包括网络 服务器 存储 应用软件和服务 这些资源能够被快速提供 只需投入很少的管理狗你工作 或与服务供应商进行很少的交
  • 独立按键控制led灯的亮灭

    独立按键控制一个led灯的亮灭 直接可以控制指定位的变化 include
  • 网上企业订货系统功能列表介绍

    网上企业订货系统功能列表介绍 企业APP订单管理软件 后台功能列表 后台支持手机版本 订货APP 管理订单的APP 后台登陆 输入账号密码登录企业订货管理软件系统 后台首页 显示近日 月 年订单统计 和收款欠款等统计 订单模块 新建订单 通
  • MES系统业务需求收集及整理

    项目小组成立后 我们简单的编制了一个项目立项考察计划表 任务名称 负责人 开始时间 完成时间 需求及功能收集整理 IT项目经理 2018年9月05日 2018年9月20日 厂商考察调研 IT项目总监 2018年9月20日 2018年10月3
  • Socket错误代码对应表(转)

    提示 在命令提示符下输入 net helpmsg 1xxxx就能够得到Windows系统提供的错误提示的详细解释 出现网络联机错误Socket error 11001 表示您的计算机无法连上服务器 请检查您的Proxy设定以及Proxy相关
  • MVVM 框架简介

    MVVM 在 iOS 中的应用 MVVM Model View ViewModel 是基于 MVC Model View Controller 和 MVP Model View Presenter 发展起来的一种新的软件设计框架 并且其包含
  • 492-SGI STL二级空间配置器(allocate内存分配)

    内存池管理函数 allocate 函数 传进去的参数 n就是用户通过容器想开辟的内存的大小 如果大于128字节 就不受内存池管理 通过malloc去 一级空间配置器 如果小于等于128字节 就由内存池管理 假设我们现在要申请13字节的内存块
  • STM32串口溢出中断问题

    之前调试程序 遇到了串口溢出中断的问题 导致主程序被卡死 这里总结分享一下经验 希望对读者有用 对于STM32F103系列单片机 使能接收中断后 溢出中断就会自动被使能 那什么时候会发生溢出中断呢 在RXNE 1 的的条件下 也就是上次数据
  • Java 8: 从永久代(PermGen)到元空间(Metaspace)

    永久代 PermGen 和元空间 Metaspace 的今世前缘 原文链接 原文作者 Monica Beckwith 以下为本人翻译 仅用于交流学习 版权归原作者和InfoQ所有 转载注明出处 请不要用于商业用途 在Java虚拟机 JVM
  • Android 拨打电话

    拨打电话 跳转到拨号界面 用户手动点击拨打 param phoneNum 电话号码 public void callPhone1 String phoneNum Intent intent new Intent Intent ACTION
  • C++使用PCL注册内存以及释放

    最近测试中发现 电脑运行一定时间就会重启 检查后发现其实是内存被占满了 然后电脑就卡住 这时会有两种情况 重启 把某些程序kill掉释放内存 这个时候不一定会kill那些占很多内存的程序 然后接着查 发现其实就是处理点云的一个程序 注册了内
  • 定时任务Schedule的使用

    定时任务或者说定时调度 是系统中比较普遍的一个功能 例如数据归档 清理 数据定时同步 非实时 定时收发 流量控制等等都需要用到定时任务 常见的定时调度框架有Quartz TBSchedule等 同样 Spring自3 0版本起也增加了任务调
  • 单片机:STM32F4x HAL库软硬SPI驱动ST7735s 1.8寸LCD屏幕

    单片机 STM32F4x HAL库软硬SPI驱动ST7735s 1 8寸LCD屏幕 说明 此篇为学习记录 可能存在错误或者不足 如有问题请指出 硬件环境 主控芯片 STM32F411CEU6 主控开发板 WeAct STM32F411CEU
  • LeetCode 817. 链表组件

    题目链接 https leetcode cn problems linked list components C 代码如下 Definition for singly linked list struct ListNode int val
  • ubuntu16.04中安装NFS服务器

    一 宿主机中对NFS服务的支持 安装相关软件 sudo apt get install nfs kernel server sudo apt get install nfs common 配置NFS服务器 编辑exports sudo vi
  • 数据结构与算法(五):优先队列

    一 基本概念 二 基于数组实现的优先队列 1 基于有序数组的实现 2 基于无序数组的实现 三 基于堆实现的优先队列 1 堆的有序化 2 基于堆实现的优先队列 四 索引优先队列 这节总结一下优先队列的常用实现方法 一 基本概念 普通的队列是一
  • python write函数换行_Python基础知识(三)

    本章小结 学习越往后越意识到总结的重要性 特别是语法基础 东西太多 不用是真的会直接忘掉 我在总结本文的时候就发现 我当时觉得学得很好很扎实 自信不会忘记的东西 真的已经被我忘掉了 还不得不依靠百度来解决问题 这坚定了我更新公众号的决心 f
  • 电调控制直流无刷电机

    实验材料 1 直流无刷电机 A2212 10 KV 1400 2 好盈天行者电调 3 stm32c8t6核心小板 先了解一下无刷电机工作原理 https www bilibili com video av29780856 电机参数 电调参数

随机推荐

  • 亚洲顶级域名.Asia启动注册

    亚洲顶级域名 Asia启动注册 详情到 http ipv1 blog sohu com 64602629 html 优先注册期将于2007年10月开始 并分为三个阶段 第一阶段专为政府机构预留 Asia域名而设 第二阶段让注册商标及服务标记
  • 扎心的前端开发

    喂喂喂 那个切图的 把页面写好就发给研发工程师套模板吧 你好 切图仔 不知道你的团队如何定义前端开发 据我所知 时至今日仍然有很多团队会把前端开发归类为产品或者设计岗位 虽然身份之争多少有些无谓 但我对这种偏见还是心存芥蒂 酝酿了许久 决定
  • Linux 磁盘管理

    参考 Ubuntu 下的磁盘管理 作者 莘莘 发布时间 2021 07 11 17 51 08 网址 https blog csdn net lcx1837 article details 118633544 spm 1001 2014 3
  • Docker之docker镜像容器文件拷贝到宿主主机

    上一篇 Docker之主机拷贝文件到docker镜像容器 介绍了怎么把主机上的文件拷贝到docker容器中 那么如果项目运行之后产生的日志文件 我们希望可以本地查看 那么就需要把产生的日志文件copy到我们本地机器上 来看看具体操作吧 这里
  • Linux运维笔记----时间和时区

    时间和时区 1 系统时间同步 1 1确定时间源地址 同步机IP 222 24 14 61 可以用date命令修改时间 被同步机IP 222 24 14 95 1 2确定客户主机使用的时间同步服务 chronyd service 1 3在ch
  • 多益网络java面试,java全栈工程师面试题

    前言 继续总结吧 没有面试就继续夯实自己的基础 前阵子的在面试过程中遇到的各种问题陆陆续续都会总结出来分享给大家 这次要说的也是面试中被问到的一个高频的问题 我当时其实没答好 因为很早之前是看过springboot启动过程的源码 但是时间隔
  • 以太坊智能合约之如何执行智能合约?

    区块链技术在顶级技术中占据主导地位的主要原因在于其去中心化 虽然区块链的主要目的是在没有中心的情况下维护交易记录 但为了实现自动化 智能合约被引入 那么在写完智能合约之后呢 在本文的这个以太坊智能合约教程中 我们将了解如何使用Truffle
  • 管理信息系统复习总结(保姆级)

    管理信息系统 题型 填空 单选 双选 名词解释 综合 简答 第一章 当今全球商业中的信息系统 1 管理信息系统的新变化 信息技术创新 新的业务模式 电子商务扩张 管理变革 公司和组织变革 2 信息系统如何改变企业 新兴移动数字平台 利用信息
  • Cas服务端5.3.2之开启审计功能(MySQL8)

    1 在cas overlay template的pom里面增加对cas server support audit jdbc的依赖
  • Redis缓存击穿

    什么是缓存击穿 在谈论缓存击穿之前 我们先来回忆下从缓存中加载数据的逻辑 如下图所示 因此 如果黑客每次故意查询一个在缓存内必然不存在的数据 导致每次请求都要去存储层去查询 这样缓存就失去了意义 如果在大流量下数据库可能挂掉 这就是缓存击穿
  • Unity打包浏览器端网页HTML(WebGL)以及部署到Tomcat浏览器访问报错问题解决

    Unity默认打包是PC端客户端程序 想要打包浏览器可以访问的WebGL网页 需要修改一些配置 我使用的Unity版本是2021 3 24f1 1 修改Build Settings 1 1 点击File Build Settings 1 2
  • C#中实现FFT的两种方法

    最近工作中有个需求 在C 环境中实现FFT算法 在网上找了些资料 最后实现了下面的两种方式 实际应用任选其一就好 第一种方法 不依赖C 中的Complex 需要实现计算过程的每一步详细步骤 输入序列长度为2的N次幂 使用前需先定义序列长度
  • 世界杯数据可视化分析

    目录 1 数据来源 2 字段解释 世界杯成绩信息表 WorldCupsSummary 世界杯比赛比分汇总表 WorldCupMatches csv 世界杯球员信息表 WorldCupPlayers csv 3 数据分析及可视化 世界杯已经告
  • 【教程】华南理工大学校园网登录抓包和协议模拟

    每次手动登录特别麻烦 而且时不时断一下 因此搞个脚本让它定时监测 断开重连比较方便 这里不讲这个脚本怎么写 只记录一下登录时的抓包内容 蒜了 直接上解析吧 也不复杂 相信大家一目了然 目录 抓包分析 postman测试请求 python模拟
  • 联想服务器如何恢复预装系统,Thinkcentre E73 E63z等预装Win7系统如何恢复出厂系统...

    故障现象 Thinkcentre系列机型 如E73 E63z等机型 随机预装win7系统如何恢复出厂系统的操作方法 解决方案 适应机型 E73 E73s E63z E93z等thinkcentre机型 适应操作系统 随机预装的Windows
  • spring boot判断需要跳转的页面文件是否存在

    在Spring Boot项目中 你可以使用ResourceLoader来判断要跳转的页面HTML路径文件是否存在 首先 你需要注入ResourceLoader到你的类中 可以使用 Autowired注解进行依赖注入 如下所示 Autowir
  • windows下搭载apache+svn服务器

    原文地址 http www cnblogs com ricksun articles 1564905 html 花了72小时 终于把 Subversion 初步掌握了 从一个连 什么是版本控制 都不知道的门外汉 到配置出精确至每目录访问的入
  • 关于AI如何实现短视频制作的方案仅供参考

    随着短视频平台的红火 短视频制作逐渐成为了大众娱乐的主流之一 同时也孕育出了巨大的商业价值 但是 短视频制作的过程需要消耗大量人力 物力 时间 并且需要调整画面的色彩 亮度 饱和度等因素 让整个过程显得较为复杂 因此 采用 AI 技术来实现
  • php-event 文档,@event

    event 描述 描述一个事件 语法 event event 概述 描述一个事件 event标签允许您描述一个可触发的事件 一个典型的事件是由对象定义的一组属性来表示 标签来定义事件的具体类型 您可以使用 fires标记 以表明这个种方法可
  • mysql isamchk_MySQL之myisamchk

    Description check and repair of MyISAM tables Used without options all tables on the command will be checked for errors