用 myisamchk 对表进行检查建议使用最新的稳定版 MySQL
解决方案 »
- 关于MYSQL的VC应用的一个不大不小的问题,请 大侠与菜鸟 之间的人来指点。
- 数据库表的设计问题
- 不知道有没有人碰到相同的情况 can't create tcp/ip socket(-1)
- 【c语言】明明执行了mysql_close,可为什么还是存在大量的ESTABLISHED链接?
- myisam联合主键大批量插入效率问题请教
- mysql 的二进制分发版 的下载链接?
- 请问该使用那个数据库?mysql听说不支持事务,是吗?
- 脑壳都想爆了,也想不出解法!帮帮我吧。要不我真想跳楼了......
- 关于服务器突然断电停机时程序往数据库中插入的数据会不会回滚?
- 请教怎么优化查询效率
- 用sql语句怎么样写???
- a question about postgresql
分析键值的分布。这通过让联结优化器更好地选择表应该以什么次序联结和应该使用哪个键来改进联结性能。
-#, --debug=debug_options
输出调试记录文件。debug_options字符串经常是'd:t:o,filename'。
-d, --description
打印出关于表的一些信息。
-e, --extend-check
非常彻底地检查表。这仅在极端情况下是必要的。通常,myisamchk应该找出所有错误,即使没有改选项。
-f, --force
覆盖老的临时文件。如果你在检查表时使用-f (运行myisamchk没有-r),myisamchk在检查期间将自动为出现一个错误的表用-r重启。
--help
显示一条帮助消息并且退出。
-i, --information
打印有关被检查的表的信息统计。
-k #, --keys-used=#
与-r一起使用。告诉ISAM表处理器仅更新头#个索引。较高编号的索引被撤销。这能用来使插入变得更快!撤销的索引能通过使用myisamchk -r被重新激活。
-l, --no-symlinks
在修复时,不跟随符号连接。通常myisamchk修复一个符号连接所指的表。
-q, --quick
与-r一起使用使得一个修复更快。通常,原来的数据文件没被接触;你能指定第二个-q强制使用原来的数据文件。
-r, --recover
恢复模式。可以修复几乎所有一切,除非唯一的键不是唯一。
-o, --safe-recover
恢复模式。使用一个老的恢复方法;这比-r慢些,但是能处理一-r不能处理的情况。
-O var=option, --set-variable var=option
设置一个变量的值。可能的变量列在下面。
-s, --silent
沉默模式。当错误发生时,仅写输出。你能使用-s两次(-ss)非常沉默地做myisamchk。
-S, --sort-index
以从高到低的顺序排序索引树块。这将优化搜寻并且将使按键值的表扫描更快。
-R index_num, --sort-records=index_num
根据一个索引排序记录。这使你的数据更局部化并且可以加快在该键上的SELECT和ORDER BY的范围搜索。(第一次做排序可能很慢!) 为了找出一张表的索引编号,使用SHOW INDEX,它以myisamchk看见他们的相同顺序显示一张表的索引。索引从1开始编号。
-u, --unpack
解开一个用myisampack压缩的表。
-v, --verbose
冗长模式。打印更多的信息。这能与-d和-e一起使用。为了更冗长,使用-v多次(-vv, -vvv)!
-V, --version
打印myisamchk版本并退出。
-w, --wait
如果表被锁定,等待。
对--set-variable(-O)选项,可能的变量是:key_buffer_size 当前值: 16776192
read_buffer_size 当前值: 262136
write_buffer_size 当前值: 262136
sort_buffer_size 当前值: 2097144
sort_key_blocks 当前值: 16
decode_bits 当前值: 9
具体请见MySQL手册
从老表把所有行拷贝到“A-xxx”。
老表被改名为“B-xxx”。
“A-xxx”被改名为你的老表的名字。
“B-xxx”被删除。
如果某些改名操作出错,MySQL试图还原改变。如果出错严重(当然,这不应该发生。),MySQL可能留下了老表为“B-xxx”但是一个简单改名就应该恢复你的数据。手册中说可以到MySQL数据目录中并删除所有名字以A-或B-开始的文件.可是我到数据目录下没有找到手册中说的文件啊!
并不是绝对的,强烈建议你使用稳定版 MySQL 4.0.13