时间:2021-04-16
每个MyISAM索引文件(.MYI)在头有一个计数器,它可以被用来检查一个表是否被恰当地关闭。如果你从CHECK TABLE或myisamchk得到下列警告,意味着这个计数器已经不同步了:
clients are using or haven't closed the table properly
这个警告并不是完全意味着表已被破坏,但你至少应该检查表。
计数器的工作方式如下:
· 表在MySQL中第一次被更新,索引文件头的计数器加一。
· 在未来的更新中,计数器不被改变。
· 当表的最后实例被关闭(因为一个操作FLUSH TABLE或因为在表缓冲区中没有空间)之时,若表已经在任何点被更新,则计数器减一。
· 当你修理或检查表并且发现表完好之时,计数器被重置为零。
· 要避免与其它可能检查表的进程进行事务的问题,若计数器为零,在关闭时计数器不减一。
换句话来说,计数器只有在下列情况会不同步:
· MyISAM表不随第一次发出的LOCK TABLES和FLUSH TABLES被复制。
· MySQL在一次更新和最后关闭之间崩溃(注意,表可能依然完好,因为MySQL总是在每个语句之间为每件事发出写操作)。
· 一个表被myisamchk --recover或myisamchk --update-state修改,同时被mysqld使用。
· 多个mysqld服务器正使用表,并且一个服务器在一个表上执行REPAIR TABLE或CHECK TABLE,同时该表也被另一个服务器使用。在这个结构中,使用CHECK TABLE是安全的,虽然你可能从其它服务器上得到警告。尽管如此,REPAIR TABLE应该被避免,因为当一个服务器用一个新的数据文件替代旧的之时,这并没有发送信号到其它服务器上。
总的来说,在多服务器之间分享一个数据目录是一个坏主意。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
MySQL临时表在我们需要保存一些临时数据时是非常有用的。临时表只在当前连接可见,当关闭连接时,Mysql会自动删除表并释放所有空间。临时表在MySQL3.23
客服外包建议之如何处理客户的投诉与抱怨?许多的客服害怕遇到来投诉或者抱怨的客户,不知道如何适当的处理问题。事实上,妥善处理客户的投诉和抱怨绝非易事,需要经验和技
1:hibernate的hql如何处理分表问题?如果不能处理,hibernate是不是比mybatis的扩展性差,灵活性差。2:wherein()效率真的很低吗
在淘宝购物难免遇到淘宝交易被卖家关闭怎么办?类似的问题,对于淘宝交易被卖家关闭怎么办该如何处理,还不知晓得话就跟着小编来看看淘宝交易被卖家关闭怎么办吧,这些
京东质量问题如何处理?当收到京东的商品,发现有质量问题,那么大家知道京东质量问题如何处理吗?赶紧跟随开淘小编去了解一下最新的京东质量问题换货规则是什么,然后