windows无法启动MySQL服务报错1067的解决方法

本文分享了一个关于Windows环境下MySQL服务启动失败报错1067的解决经验,作者因误删mysql.user表导致问题,通过查找并复制缺失的user相关文件到正确目录,成功解决了服务启动问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这个问题一直困扰了我很久,因为我比较喜欢清爽,看到mysql中的很多数据库都想把他里面的数据库删掉。然后重新建一个自己的数据库。殊不知,这样做给自己埋下了很多隐患,就比如“windows无法启动MySQL服务报错1067的解决方法”。

去百度搜索,找到的都是什么删掉配置文件,重现安装,重新安装时可以的,但是我每次手贱都把mysql自带的数据库删掉,因此,下次开机又不知道为什么会又不行了。还因为这个原因,把电脑重装了系统。装完之后,装mysql又把mysql自带的数据库删掉,然后又不行了,如此循环,简直要崩溃了。

这次学乖了,昨天晚上,测试数据库的连接情况,把mysql.user表删掉,第二天手动重启mysql又出现windows无法启动MySQL服务报错1067的报错提示。就去网上搜了一下。

突然被我看到有说到因为mysql.user表的问题,我想起来了昨天晚上正好删了mysql数据库中的user表,不会真的是这个问题吧?

抱着试试看的想法,按照提示 
网上这么说:

   

    找到mysql安装目录,找到basedir、datadir的配置,找到这个目录,我的电脑是:

basedir="F:/Databases/MySQL5.5/"

datadir="C:/ProgramData/MySQL/MySQL Server 5.5/Data/"

在datadir 目录下,有一个.err文件,打开之后看到文档最后一行有错误提示:170507 15:43:29 [ERROR] Fatal error: Can't open and lock privilege tables: Table 'mysql.user' doesn't exist。


我没有basedir 这个目录,但是我知道下载后软件位置 和安装位置在哪里,只要谁有这个user开头的文件就是我要复制的。 
我的是在这个文件下mysql少了三个user开头的文件, 
C:\ProgramData\MySQL\MySQL Server 5.5\data\mysql

1.找文件

然后我去下面这个目录下找到有user开头的文件 

è¿éåå¾çæè¿°
这上面的文件就是我要拷贝的user开头的三个文件,进行拷贝,

如果发现自己的目录里没有这三个文件,可以下载一个新的mysql将文件拷贝进去

2.然后转到缺少这三个文件的文件夹中去,我的是下面这个

C:\ProgramData\MySQL\MySQL Server 5.5\data\mysql 

è¿éåå¾çæè¿°
黏贴进去,然后再打开服务。 
点击启动。发现mysql服务正常启动。

 è¿éåå¾çæè¿°
太神奇了有木有。

总结: 
果然还是要看报错信息啊。不然就跟瞎子一样到处乱碰!!! 
洋人的东西不要乱删!!!
————————————————
版权声明:本文为优快云博主「何厚勋」的原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.youkuaiyun.com/hejiajiaming/article/details/78230481

### MySQL 启动报错 1067解决方案 当 MySQL 启动时遇到错误代码 1067,通常表示服务无法正常启动。这种问题可能由多种原因引起,例如权限不足、配置文件错误、数据目录损坏或重复启动服务等。以下是详细的解决方法: #### 1. 检查权限设置 如果以非管理员身份运行命令行工具或安装程序,可能会导致权限不足的问题。确保使用管理员权限打开命令提示符,并重新尝试启动服务[^2]。 ```cmd net stop mysql net start mysql ``` #### 2. 验证配置文件路径和内容 检查 `my.ini` 或 `my.cnf` 文件中的配置是否正确。特别是以下关键参数需要确认无误: - `basedir`:指定 MySQL 的安装目录。 - `datadir`:指定 MySQL 数据库的数据存放目录。 - 确保这些路径存在并且具有正确的读写权限[^3]。 示例配置文件内容如下: ```ini [mysqld] basedir=D:\mysql\ datadir=D:\mysql\data\ port=3306 ``` #### 3. 检查日志文件 MySQL 的错误日志通常位于数据目录下(如 `D:\mysql\data\`),文件名可能是 `hostname.err`。通过查看该日志文件,可以获取更详细的错误信息,从而定位问题[^4]。 #### 4. 杀掉冲突的进程 如果系统中存在多个 MySQL 进程,可能导致服务无法正常启动。可以通过以下步骤解决: - 使用任务管理器或命令行查找并终止所有与 MySQL 相关的进程。 - 命令行中输入以下命令以强制结束进程: ```cmd taskkill /F /IM mysqld.exe ``` 之后再次尝试启动服务[^1]。 #### 5. 兼容性模式运行 某些情况下,操作系统与 MySQL 版本之间的兼容性问题也可能导致服务启动失败。尝试以下操作: - 右键点击 MySQL 安装程序或服务管理工具,选择“属性”。 - 在“兼容性”选项卡中,勾选“以兼容模式运行这个程序”,并选择一个较旧的操作系统版本(如 Windows XP SP3)[^4]。 #### 6. 检查端口占用情况 默认情况下,MySQL 使用 3306 端口。如果该端口被其他程序占用,也会导致服务启动失败。可以使用以下命令检查端口占用情况: ```cmd netstat -ano | findstr :3306 ``` 如果发现端口被占用,可以选择更改 MySQL 的监听端口或关闭占用端口的程序[^3]。 #### 7. 重新安装 MySQL 如果以上方法均无效,可以考虑卸载并重新安装 MySQL。在重新安装之前,请确保备份数据目录中的内容,避免数据丢失。 --- ### 示例代码:修改 MySQL 端口 如果需要更改 MySQL 的端口,可以在配置文件中进行如下修改: ```ini [mysqld] port=3307 ``` 然后重启服务以应用更改。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值