当我们忘记mysql数据库密码时我们就无法正常进入数据库,也就无法修改密码,那么这时该怎么修改密码呢,这里教大家一个简单常用修改密码的方式。

工具/原料

 
  • mysql数据库
  • cmd命令行

方法/步骤

 
  1. 1

    打开mysql.exe和mysqld.exe所在的文件夹,复制路径地址

    技术分享图片
  2. 2

    打开cmd命令提示符,进入上一步mysql.exe所在的文件夹。

    技术分享图片
  3. 3

    输入命令  mysqld --skip-grant-tables  回车,此时就跳过了mysql的用户验证。注意输入此命令之后命令行就无法操作了,此时可以再打开一个新的命令行。注意:在输入此命令之前先在任务管理器中结束mysqld.exe进程,确保mysql服务器端已结束运行。

    技术分享图片
  4. 4

    然后直接输入mysql,不需要带任何登录参数直接回车就可以登陆上数据库。

    技术分享图片
  5. 5

    输入show databases;   可以看到所有数据库说明成功登陆。

    技术分享图片
  6. 6

    其中mysql库就是保存用户名的地方。输入 use mysql;   选择mysql数据库。

    技术分享图片
  7. 7

    show tables查看所有表,会发现有个user表,这里存放的就是用户名,密码,权限等等账户信息。

    技术分享图片
  8. 8

    输入select user,host,password from user;   来查看账户信息。

    技术分享图片
  9. 9

    更改root密码,输入update user set password=password(‘123456‘) where user=‘root‘ and host=‘localhost‘;

    技术分享图片
  10. 10

    再次查看账户信息,select user,host,password from user;   可以看到密码已被修改。

    技术分享图片
  11. 11

    退出命令行,重启mysql数据库,用新密码尝试登录。

    技术分享图片
  12. 12

    测试不带密码登录mysql,发现还是能够登陆上,但显示数据库时只能看到两个数据库了,说明重启之后跳过密码验证已经被取消了。

    技术分享图片
  13. 13

    我这地方重启数据库之后之所以不带密码任然能够登录是因为我的数据库里存在设无须口令的账户。

    技术分享图片
    END

注意事项

 
  • 注意其中需要重启数据库的几个地方
 
经验内容仅供参考,如果您需解决具体问题(尤其法律、医学等领域),建议您详细咨询相关领域专业人士。
举报作者声明:本篇经验系本人依照真实经历原创,未经许可,谢绝转载。
 
 
 
 
###############2
 

阿里云服务器 ECS上,安装完MySQL数据库后,在本地能连接上,远程连接不上,一直报10060的错误,如下图:

技术分享图片
 

工具/原料

 
  • 阿里云服务器 ECS
  • 安装MySQL

方法/步骤

 
  1.  

    查看MySQL进程是否正常,可以阿里云服务器 ECS 服务器上输入:ps -ef|grep mysqld

    mysqld_safe和mysqld都在,说明MySQL进程是正常,若没有这两进程,执行/etc/init.d/mysqld start,启动msyql。

    技术分享图片
  2.  

    查看mysql监听IP和端口是否正常。

    使用:netstat -anpt

    监听得地址如果是:::3306或者是0.0.0.0:3306,表示监听所有IP地址,这监听状态是正常。若出现127.0.0.0:3306,说明监听的本地地址,需要在mysql配置文件中将bind-address选项设置为bind-address = 0.0.0.0,重启mysql。

    技术分享图片
  3.  

    查看用于远程访问的mysql用户权限是否正确。

    在本地登入mysql服务器,

    use mysql;

    SELECT user, host from mysql.user; 查看用于远程访问的mysql用户host的权限,%表示允许所有机器访问。若host为127.0.0.1/localhost,那么这个用户就只能本机访问,则需要将host改为%,可以使用update user set host=‘%‘ where user=‘root‘;

    技术分享图片
    技术分享图片
  4.  

    若以上操作都正常,还是远程还是不能访问的话,可以使用tcpdump在服务器端抓一下3306端口,看是否有数据包,排查以下网络原因。

    在服务上输入抓包命令:tcpdump port 3306

    然后远程连接mysql数据库,看一下服务端是否有数据包。

    技术分享图片
  5.  

    如果没有数据包,查一下阿里云服务器 ECS下的安全组件中的配置

    技术分享图片
  6.  

    若安全组件中的配置中,入口未对数据库服务监听的3306端口放开,则需要将3306端口放开。如下图,并没有3306端口,则表示未放开该端口。

    技术分享图片
    技术分享图片
  7.  

    在阿里云服务器 ECS下的安全组件中的配置,放开3306端口。单击添加安全组规则,如下图:

    技术分享图片
    技术分享图片
  8.  

    以上操作基本上可以排查问题得所在原因了,要是还有问题,可以留言讨论;若对您有帮助,请在下方投个票。