MySQL 问题

md198687 2010-03-24 10:18:04
错误信息!
Discuz! info: MySQL Query Error

Time: 2010-3-24 10:16am
Script: /viewthread.php

SQL: SELECT p.*, m.uid, m.username, m.groupid, m.adminid, m.regdate, m.lastactivity, m.posts, m.digestposts, m.oltime,
m.pageviews, m.credits, m.extcredits1, m.extcredits2, m.extcredits3, m.extcredits4, m.extcredits5, m.extcredits6,
m.extcredits7, m.extcredits8, m.email, m.gender, m.showemail, m.invisible, m.xspacestatus, mf.nickname, mf.site,
mf.icq, mf.qq, mf.yahoo, mf.msn, mf.taobao, mf.alipay, mf.location, mf.medals, mf.avatar, mf.avatarwidth,
mf.avatarheight, mf.sightml AS signature, mf.customstatus, mf.spacename
FROM [Table]posts p
LEFT JOIN [Table]members m ON m.uid=p.authorid
LEFT JOIN [Table]memberfields mf ON mf.uid=m.uid
WHERE p.tid='6804' AND p.invisible='0' ORDER BY dateline LIMIT 0, 15
Error: Table '.\hsdiscuz5\hsdb_members' is marked as crashed and should be repaired
Errno.: 145

Similar error report has beed dispatched to administrator before.
我不会用MySQL数据库的,这是之前同事做的,现在我在维护,刚好用到MySQL
请高手指点
...全文
73 7 打赏 收藏 转发到动态 举报
写回复
用AI写文章
7 条回复
切换为时间正序
请发表友善的回复…
发表回复
md198687 2010-03-24
  • 打赏
  • 举报
回复
MySQL Command Line Client
用户名密码一输入进去
敲回车就不见了
md198687 2010-03-24
  • 打赏
  • 举报
回复
为什么dos窗体,我一敲回车就不见了。
md198687 2010-03-24
  • 打赏
  • 举报
回复
我同事装的MySQL Server 5.0 的
是一个dos命令的窗体
我在里面输入,
命令:mysql -uusername -ppassword
然后一敲回车,dos窗体就不见了
ACMAIN_CHM 2010-03-24
  • 打赏
  • 举报
回复
MySQL官方文档 http://dev.mysql.com/doc/refman/5.1/zh/index.html

[Quote]15.1.4. MyISAM表方面的问题
15.1.4.1. 损坏的MyISAM表

15.1.4.2. 未被适当关闭的表的问题

MySQL用来存储数据的文件格式已经被广泛测试过,但总是有导致数据表变得损坏的环境。

15.1.4.1. 损坏的MyISAM表
即使MyISAM表格式非常可靠(SQL语句对表做的所有改变在语句返回之前被写下),如果下列任何事件发生,你依然可以获得损坏的表:

· mysqld进程在写中间被杀掉。

· 发生未预期的计算机关闭(例如,计算机被关闭)。

· 硬件故障。

· 你可以同时在正被服务器修改的表上使用外部程序(如myisamchk)。

· MySQL或MyISAM代码的软件缺陷。

一个损坏的表的典型症状如下:

· 当在从表中选择数据之时,你得到如下错误:

· Incorrect key file for table: '...'. Try to repair it
· 查询不能在表中找到行或返回不完全的数据。

你可以用CHECK TABLE statement语句来检查MyISAM表的健康,并用REPAIR TABLE修复一个损坏的MyISAM表。当mysqld不运行之时,你也可以用myisamchk命令检查或修理一个表。请参阅13.5.2.3节,“CHECK TABLE语法”, 13.5.2.6节,“REPAIR TABLE语法”,和5.9.5节,“myisamchk — MyISAM表维护工具”。

如果你的表变得频繁损坏,你应该试着确定为什么会这样的原因。要明白的最重要的事是表变得损坏是不是因为服务器崩溃的结果。你可以在错误日志中查找最近的restarted mysqld消息来早期验证这个。如果存在这样一个消息,则表损坏是服务器死掉的一个结果是很有可能的。否则,损坏可能在正常操作中发生。这是一个缺陷。你应该试着创建一个展示这个问题的可重复生成的测试案例。请参阅A.4.2节,“如果MySQL保持崩溃,该怎么做” 及E.1.6节,“如果出现表崩溃,请生成测试案例”。

15.1.4.2. 未被适当关闭的表的问题
每个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应该被避免,因为当一个服务器用一个新的数据文件替代旧的之时,这并没有发送信号到其它服务器上。

总的来说,在多服务器之间分享一个数据目录是一个坏主意。请参阅5.12节,“在同一个机器上运行多个MySQL服务器” 获得更多地讨论

[/Quote]
ACMAIN_CHM 2010-03-24
  • 打赏
  • 举报
回复
Error: Table '.\hsdiscuz5\hsdb_members' is marked as crashed and should be repaired

表需要修复一下了。

mysql> repair table hsdb_members;

wwwwb 2010-03-24
  • 打赏
  • 举报
回复
检查hsdb_members表是什么引擎,修复一下
ACMAIN_CHM 2010-03-24
  • 打赏
  • 举报
回复
看来你需要先花10分钟看一下手册中的教程部分。

[Quote]3. 教程
3.1. 连接与断开服务器
3.2. 输入查询
3.3. 创建并使用数据库
3.3.1. 创建并选择数据库
3.3.2. 创建表
3.3.3. 将数据装入表中
3.3.4. 从表检索信息
3.4. 获得数据库和表的信息
3.5. 在批处理模式下使用mysql
3.6. 常用查询的例子
3.6.1. 列的最大值
3.6.2. 拥有某个列的最大值的行
3.6.3. 列的最大值:按组
3.6.4. 拥有某个字段的组间最大值的行
3.6.5. 使用用户变量
3.6.6. 使用外键
3.6.7. 根据两个键搜索
3.6.8. 根据天计算访问量
3.6.9. 使用AUTO_INCREMENT
3.7. 孪生项目的查询
3.7.1. 查找所有未分发的孪生项
[/Quote]

56,687

社区成员

发帖
与我相关
我的任务
社区描述
MySQL相关内容讨论专区
社区管理员
  • MySQL
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧