欢迎各位兄弟 发布技术文章

这里的技术是共享的

You are here

phpmyadmin显示MySQL数据表“使用中” 修复后依然无效的解决方法

shiping1 的头像

PHP+MySQL后台,部分程序页面不显示内容,错误提示出错,需要修复。

打开phpmyadmin选择数据库查看,果然有3个表显示为“使用中”。勾选之后进行“修复表”,出现错误提示不能被修复。

于是接着从“分析表”、“优化表”开始,均告失败。失败信息第一条:can't create new temp file

google解决方案:强制修复 myisamchk -r -f ****.MYI,问题依旧。

第一步:停掉MYSQL服务,cmd命令:net stop mysql。
第二步:保险起来,把整个数据库文件夹都备份起来。
第三步:打开数据库所在的文件夹,找到损坏表的系统自动生成的文件(xxxx.TMD),改名(xxx.MYD)。
第四步:执行修复命令:myisamchk -r D:/MYSQLdata/数据库名称*.MYI (记住:这里mysql服务是停止的)需要CMD命令进入mysql的bin目录
第五步:启动MYSQL服务,net start mysql。
第六步:再执行命令: mysqlcheck -o -r 数据库名称 -u root -p (适当改为你的MYSQL管理员名称),运行后提示输入密码。

继续检查有无写入权限,同样不能解决问题。

最后只有考虑磁盘空间是否不够写入?检查盘符容量,果然。磁盘清理后问题自动解决。


来自   http://www.soso.io/article/13644.html




相关推荐
 

使用PHPMyAdmin修复论坛数据库的图文方法

1、登录 phpMyAdmin,进入 phpMyAdmin 数据列表页面; 2、选择一个数据表前的方框; 3、页面下方“选中项”下拉选择“修复表”;

js中style.display=""无效的解决方法

本文实例讲述了js中style.display=""无效的解决方法。分享给大家供大家参考。具体解决方法如下: 一、问题描述: 在js中我们有时想动态的控制一个div显示或隐藏或更多的操作,但如果我们style.display=""可能导致没有效果。 看下面一段代码: 代码如下: <style> #name {

mysql 导入导出数据库、数据表的方法

Linux下均在控制台下操作。导入数据库:前提:数据库和数据表要存在(已经被创建) (1)将数据表 test_user.sql 导入到test 数据库的test_user 表中[root@test ~]# mysql -uroot -p test < /www/web/test/test_user.sql (2) 将数据库 test.sql 导入到 test 数据库test 中[root@t

mysql修复数据表的命令方法

所有数据库 代码如下: mysqlcheck --auto-repair -A -o -uroot -pyigeorg 单一数据库 代码如下: mysqlcheck --auto-repair --databases yige -o -uroot -pyigeorg 这样就搞定了。

MYSQL使用.frm恢复数据表结构的实现方法

我们都知道当我们建立数据表(innodb或myisam)时,会生成相应的文件(如:MYD,MYI,frm) 在这里,我们探讨下使用frm文件恢复 innodb和myisam类型表的结构,不过由于他们存储引擎的特性,所以恢复的方法也不一样,以下是详细的恢复过程。 myisamchk "xxx.frm" myisamchk 可以试出来,库是不是 myisam 类型 1:恢复i

MySQL数据表损坏的正确修复方案

于断电或非正常关机而导致MySQL(和PHP搭配之最佳组合)数据库出现错误是非常常见的问题。有两种方法,一种方法使用MySQL(和PHP搭配之最佳组合)的check table和repair table 的sql语句,另一种方法是使用MySQL(和PHP搭配之最佳组合)提供的多个myisamchk, isamchk数据检测恢复工具。前者使用起来比较简便。推荐使用。   1. check tab

MYSQL数据表损坏的原因分析和修复方法小结

1.表损坏的原因分析 以下原因是导致mysql 表毁坏的常见原因: 1、 服务器突然断电导致数据文件损坏。 2、 强制关机,没有先关闭mysql 服务。 3、 mysqld 进程在写表时被杀掉。 4、 使用myisamchk 的同时,mysqld 也在操作表。 5、 磁盘故障。 6、 服务器死机。 7、 mysql 本身的bug 。 2.表损坏的症状 一个损坏的表的典型症状如下: 1 、当在从

Sql Server中清空所有数据表中的记录

Sql Server中清空所有数据表中的记录 清空所有数据表中的记录: 代码如下: exec sp_msforeachtable @Command1 ='truncate table ?' 删除所有数据表: 代码如下: exec sp_msforeachtable 'delete N''?''' 清空SQL Server数据库中所有

一次非法关机导致mysql数据表损坏的实例解决

排查修复数据表的经过: 1、访问网页,提示错误,连接不到数据库。 2、启动mysql服务,卸载和关闭rpm安装的mysql服务(昨天安装postfix好像yum安装了mysql),用netstat -anp |grep mysqld 命令查看mysql服务没有起来,用mysql -uroot -p也连接不到服务器。 3、查看错误提示:110726 17:02:23 [ERROR] Can't op

PHP中file_exists()判断中文文件名无效的解决方法

本文实例讲述了PHP中file_exists()判断中文文件名无效的解决方法。分享给大家供大家参考。具体方法如下: php中判断文件是否存在我们会使用file_exists函数或is_file函数,但在使用file_exists时如果你文件名或路径是中文在uft8编码文档时是无效。本文就来解决此问题,下面我们一起来看看。 定义和用法: file_exists() 函数检查文件或目录是否存在。 如果

mysql数据库修改数据表引擎的方法

对于MySQL数据库,如果你要使用事务以及行级锁就必须使用INNODB引擎。如果你要使用全文索引,那必须使用myisam。 INNODB的实用性,安全性,稳定性更高但是效率比MYISAM稍差,但是有的功能是MYISAM没有的。修改MySQL的引擎为INNODB,可以使用外键,事务等功能,性能高。 查看数据表的状态 代码如下: SHOW TABLE STATUS FROM sites WH

php中批量删除Mysql中相同前缀的数据表的代码

方法一: 代码如下: <?php mysql_connect('','',''); mysql_select_db(''); $rs=mysql_query('show tables'); while($arr=mysql_fetch_array($rs)){ $TF=strpos($arr[0],'class_'); if($TF===0){ $FT=mysql_query(&q

MySQL如何去除数据表中的重复数据

通常情况下,一个我们在做一个产品的时候,一开始可能由于设计考虑不周或者程序写的不够严谨,某个字段上的值产生重复了,但是又必须去掉,这个时候就稍微麻烦了一点,直接加一个 UNIQUE KEY 肯定是不行了,因为会报错。 现在,我们来采用一种变通的办法,不过可能会丢失一些数据

使用asp.net 2.0的CreateUserwizard控件如何向自己的数据表中添加数据

在我们的应用系统中,asp.net 2.0的用户表中的数据往往不能满足我们的需求,还需要增加更多的数据,一种可能的解决方案是使用Profile,更普遍的方案可能是CreateUserwizard中添加数据到我们自己的表中。 在结合asp.net 2.0的用户管理系统设计的保存用户额外信息的表中的主键是用户表ID的外键,你可以获取ID从Membershipuser属性Provideruserkey

Win8/8.1下驱动安装“数据无效”错误的有效解决方法

如果你使用的是Windows8或者8.1,并且精简过系统,那么在安装驱动程序的过程中,你可能会遇到“数据无效”的错误。笔者确信所拥有的驱动程序是可以安装在Win8/Win8.1的系统中的,但是查阅了网络上关于所有安装驱动程序过程中出现“数据无效”的解决方法,都尝试无果,后来终于摸索出行之有效的解决方法——开启服务,屡试不爽。 原来,微软在Windows 8/8.1中对硬件设备管理的服务独立出来,如

MySQL插入数据时插入无效列的解决方法

1、错误描述 com.mysql.jdbc.exception:jdbc4.MySQLSyntaxErrorException:Unknown column 'man' in 'field list' 2、错误原因 数据库表中的字段:sno sname sage ssex 插入数据时: sno sname sage man 本来是想插入ssex这个字段的值为“man”,结果将man弄成了ssex字

SQL中函数 replace 的参数1的数据类型ntext无效的解决方法

今天将一个ACC的数据库转换成ms-sql以后发现在使用replace替换语句的时候出现: SQL中函数 replace 的参数 1 的数据类型 ntext 无效。找了半天找到了解决办法: 因为ntext需要转化下 用如下语句即可解决: 代码如下: UPDATE 表 SET 字段=REPLACE(cast(字段 AS varchar(8000)),'被替换的内容','将要替换成的内容'

Oracle 数据表分区的策略

正在看的ORACLE教程是:Oracle 数据表分区的策略。本文描述通过统计分析出医院信息系统需分区的表,对需分区的表选择分区键,即找出包括在你的分区键中的列(表的属性),对大型数据的管理比较有意义,本文的工作在Oracle8.1.6下实现。   Oracle虽然是一个大型的DBMS,但如果不对记录比较多的表进行处理,仍然发挥不了Oracle管理大型数据的强大功能,因此对某些表进行分

SQL Server2005打开数据表中的XML内容时报错的解决办法

从SQL Server2005开始提供了一种新的数据类型XML type,它允许用户将数据以XML文件的格式直接存储到数据表中。结合在ASP.NET中使用Linq to Sql,我们可以非常方便地将XML文件存储到SQL Server数据库中。但是在默认情况下,如果你存储的XML文件比较大(超过2MB),在SQL Server管理器中不能直接点击查看XML内容而报以下错误提示:   如何解决该问

Oracle数据表分区的策略

正在看的ORACLE教程是:Oracle数据表分区的策略。 本文描述通过统计分析出医院信息系统需分区的表,对需分区的表选择分区键,即找出包括在你的分区键中的列(表的属性),对大型数据的管理比较有意义, 本文的工作在Oracle8. 1.6下实现。  Oracle虽然是一个大型的DBMS,但如果不对记录比较多的表进行处理,仍然发挥不了Oracle管理大型数据的强大功能,因此对某些表进行分区,具有如下

聊天室php&mysql(六)

#相应的数据库 # phpMyAdmin MySQL-Dump # http://phpwizard.net/phpMyAdmin/ # # 主机: localhost:3306 数据库 : study28 # -------------------------------------------------------- # # 数据表的结构

MYSQL数据库中的现有表增加新字段(列)

代码如下: ALTER TABLE `数据库名`.`表名` ADD COLUMN `PROCID` VARCHAR(6) DEFAULT '' AFTER `PPIDChanged`; --在MYSQL中,如果是表名,数据库名,列名,在你增加,修改,更新的时候都需要使用ESC键盘下的重音符号,才可以添加,相应的列名或者更新修改。 当然现在大多都是用phpmyadmin或mysql图形化操

BBS(php & mysql)完整版(八)

//完毕 wish you sucess!! # phpMyAdmin MySQL-Dump # http://phpwizard.net/phpMyAdmin/ # # 主机: localhost:3306 数据库 : database # -------------------------------------------------------- # # 数据表的结构 'bbs_html

win7系统中启动修复无法自动修复此计算机情况的三种解决方法介绍

使用Windows 7操作系统开机提示自动修复,无法正常进入操作系统。经过分析,部分系统修复报错文件为:X:\Windows\system32\drivers\spoon.sys 如下图: 解决方法: 方法一: 1. 开机连续敲击键盘“F8”按键,进入“系统高级选项菜单”,选择“最后一次正确配置”如下图: 2. 如可以常进入操作系统,请指导用户删除如下路径的spoon.sys文件:

快速修复损坏的MySQL数据库

1、myisamchk 使用 myisamchk 必须暂时停止 MySQL 服务器。例如,我们要检修 discuz 数据库。执行以下操作: # service mysql stop (停止 MySQL ); # myisamchk -r /数据库文件的绝对路径/*MYI # service mysql start myisamchk 会自动检查并修复数据表中的索引错误。 2、mysqlcheck

MySQL修改数据表存储引擎的3种方法介绍

MySQL作为最常用的数据库,经常遇到各种各样的问题。今天要说的就是表存储引擎的修改。有三种方式,列表如下。 1.真接修改。在数据多的时候比较慢,而且在修改时会影响读取性能。my_table是操作的表,innoDB是新的存储引擎。 代码如下: ALTER TABLE my_table ENGINE=InnoDB 2.导出,导入。这个比较容易操作,直接把导出来的sql文件给改了,然后再

mysql中Table is read only的解决方法小结

如果是使用中的数据库突然出现些类问题 在Linux下面执行下面命令就可以了,当然你要找到你的mysql目录 linux中 代码如下: /usr/local/mysql/bin/mysqladmin -u root -p flush-tables windows中 可以在cmd中执行lush-tables 也可以在phpmyadmin 直利用修复表进行修改 如果是导入还原数据 ,所

Oracle数据更改后出错的解决方法

在使用Oracle的过程中我们给系统创建了两个用户:com和comtest。前者存放的是正式库数据,后者存放的测试库数据。它们都有一个taw_rm_user表,存放了使用该系统的用户基本信息,于是就是把其中的password字段全部改成了123456。 DMP备份文件创建后,经过一段时间创建了几个新的用户,并且有些旧的用户的其他信息也已经更改了。但是需要把旧用户的密码恢复到从前,直接把备份文件中的

XP升级到Vista失败后无法启动只显示黑屏的解决方法

当您在升级到 Windows Vista 失败后尝试启动,但却不能进入Windows XP 系统也无法进入vista,而是显示黑屏以及一条闪烁的底线。 当出现这种问题时该如何解决呢?看看下面的解决步骤吧: 1、使用 Windows XP CD 启动计算机。 2、在“欢迎使用安装程序”屏幕上,按 R 修复 Windows。 3、登录到要修复的 Windows XP 安装中。 4、键入 fi

phpmyadmin中禁止外网使用的方法

本文实例讲述了phpmyadmin中禁止外网使用的方法。分享给大家供大家参考。具体方法如下: 首先,在phpmyadmin文件夹中找到 phpmyadmin.conf 在文件中能看到如下面一段配置 代码如下: <Directory "c:/wamp/apps/phpmyadmin3.4.10.1/"> Options

Win8蓝牙正常连接后显示脱机状态的解决方法

Windows 8正常连接设备后,显示为脱机状态:   原因分析:Windows 8正常连接后,如果没有双击打开进行传输文件,会显示脱机状态,应该是Windows 8的一个特殊功能,类似节电,通过双击打开进行传输后正常。   解决方法:目前通过简单测试,正常连接过程:   连接过程会弹出如上图显示,自动添加设备驱动程序,完成添加后,在设备管理器中会显示此设备:   如正常显示出驱

Sql Server里删除数据表中重复记录的例子

[项目] 数据库中users表,包含u_name,u_pwd两个字段,其中u_name存在重复项,现在要实现把重复的项删除! [分析] 1、生成一张临时表new_users,表结构与users表一样; 2、对users表按id做一个循环,每从users表中读出一个条记录,判断new_users中是否存在有相同的u_name,如果没有,则把它插入新表;如果已经有了相同的项,则忽略此条记录; 3、把u

php 字符串中的\n换行符无效、不能换行的解决方法

例如下面的代码: 代码如下: <?php echo 'hello\n'; echo 'world'; ?> 程序的中的换行符\n会直接输出,无法正确换行,解决方法是把单引号改为双引号: 代码如下: <?php echo "hello\n"; echo "world"; ?> 这样就可以了!其实就是PHP的双引号和

IE浏览器中图片onload事件无效的解决方法

故事模式实现是只加载当前浏览的照片和它下面的两张照片,加载照片的时候才会加载和渲染评论区,图片没有加载前会用一个一象素的图片占位,并用一个loading类将显示出一个loading背景图,判断在可视区的时候替换成真正的图片,图片加载成功后删除loading类。 问题出在最后面,测试的时候发现在IE下loading类无法删除,当时代码如下: 代码如下: img.src = _src; img

IE中图片的onload事件无效问题和解决方法

在web开发在获取图片宽高是很正常的事情,图片在加载完成前是获取不到图片的宽高的,在加载完成后才可以获取图片本身的宽高,例如: 代码如下: var img = new Image(); img.src = "loading.gif"; img.onload = function(){ alert ( img.width ); }; OK?这段代码看着没

js中的onchange和onpropertychange (onchange无效的解决方法)

笔者注:今天我在用到onchange事件时没有任何反应,最后翻查资料才知道Onchange的局限性和不稳定性。而onpropertychange却能很好的实现尤其是它的实时捕捉性能更是很值得用一下(幸亏有这个性能,做出的东西老板娘很满意 o(∩_∩)o...)。 本人也比较懒,自己亲自做的东西也懒的整理下来只能把搜索到的资料原版拿来个大家分享一下: IE下,当一个HTML元素的属性改变的时候,都能通过

PHPMYADMIN导入数据最大为2M的解决方法

PHPMYADMIN是经常使用的一个MySql管理工具,备份和还原是PHPMYADMIN的重要功能,在还原数据库的时候经常遇到这样的一个情况:PHPMYADMIN还原数据库的时候上传的最大限制:2,048 KB,数据库稍微大一些就无法处理,要么使用其他的备份还原工具如帝国备份王,要么就分卷导出,那么有没有办法还使用PHPMYADMIN来处理呢?肯定可以的,根据下面的步骤来吧。 以WINDOWS2

php ob_flush,flush在ie中缓冲无效的解决方法

PHP程序的缓冲,而不论PHP执行在何种情况下(CGI ,web服务器等等)。该函数将当前为止程序的所有输出发送到用户的浏览器。 flush() 函数不会对服务器或客户端浏览器的缓存模式产生影响。因此,必须同时使用 ob_flush() 和flush() 函数来刷新输出缓冲。 个别web服务器程序,特别是Win32下的web服务器程序,在发送结果到浏览器之前,仍然会缓存脚本的输出,直到程序结束为止

mysql启动服务报1058错误的解决方法

今天研究一个框架,数据库使用mysql,启动mysql服务的时候报1058错误,如下图。 在网上找了半天都是一样的解决 办法,试了一遍通通不行(仅针对我本地服务启动出现的问题无效)。网上解决办法如下:、 新启动,却无法启动. 解决方法: ◆1、运行 D:\mysql\bin>mysqld-nt -remove Service successfully removed

Oracle对两个数据表交集的查询

正在看的ORACLE教程是:Oracle对两个数据表交集的查询。 Oracle关系型数据库管理系统是世界上流行的关系数据库,它是一个极其强大、灵活和复杂的系统,据说,在使用oracle时应有这样的思想,那就是在SQL中几乎可以实现任何一种想法。   下面向大家介绍使用SQL查两个Oracle数据表查询的相同数据的方法,笔者感到这两种方法执行效率高、使用方便。   第一种方法:利用操作符inters


 

普通分类: