-->

科技资讯

您的当前位置:首页 > 资讯 > MySQL

MySQL密码忘记了怎么办

2020-04-16 15:57:53  来源:admin 点击:615

修改的用户都以root为列。

一、知道原来的myql数据库的root密码;

①: 在终端命令行输入 mysqladmin -u root -p password "新密码" 回车 ,Enter password: 【输入原来的旧密码】
②: 登录mysql系统修改, mysql -uroot -p 回车 Enter password: 【输入原来的密码】

mysql>use mysql;

mysql> update user set password=password("新密码") where user='root';        【密码注意大小写】

mysql> flush privileges;

mysql> exit;      

然后使用刚才输入的新密码即可登录。

二、不知道原来的myql的root的密码;
首先,你必须要有操作系统的root权限了。要是连系统的root权限都没有的话,先考虑root系统再走下面的步骤。 类似于安全模式登录系统。

需要先停止mysql服务,这里分两种情况,一种可以用service mysqld stop,

另外一种是/etc/init.d/mysqld stop

当提示mysql已停止后进行下一步操作   Shutting down MySQL. SUCCESS!

在终端命令行输入

mysqld_safe --skip-grant-tables &         【登录mysql系统】

输入mysql登录mysql系统

mysql> use mysql;

mysql> UPDATE user SET password=password("新密码") WHERE user='root';      【密码注意大小写】

mysql> flush privileges;

mysql> exit;

重新启动mysql服务

这样新的root密码就设置成功了。

 

三、修改root登录权限

当你修改好root密码后,很有可能出现这种情况

ERROR 1045 (28000): Access denied for user 'root'@'localhost' (using password: YES)

这是因为root登录权限不足,具体修改方法如下

需要先停止mysql服务,这里分两种情况,一种可以用service mysqld stop,

另外一种是/etc/init.d/mysqld stop

当提示mysql已停止后进行下一步操作   Shutting down MySQL. SUCCESS!

在终端命令行输入

mysqld_safe --skip-grant-tables         【登录mysql系统】

在切换一个终端

输入MySQL -u root 进入修改

输入mysql登录mysql系统

mysql>use mysql;

mysql>update user set host = '%' where user = 'root';

mysql>select host, user from user;

mysql> flush privileges;

mysql> exit;

然后重新启动mysql服务就可以了。

从软件管理器下载安装的mariadb10,发现用默认密码登录不进。首先修改配置文件,跳过密码登录,如下解决:

1. /etc/init.d/mysql stop
. 编辑配置文件,我的配置文件在/etc/mysql/mariadb.conf.d目录下。先检查/etc/mysql/my.cnf里看有没有[mysqld]配置块,若没有则继续找找该目录下的所有配置文件。
  vim /etc/mysql/mariadb.conf.d/50-server.cnf
3. 在[mysqld] 下添加  skip-grant-tables=1
4.  /etc/init.d/mysql start

5.   mysql -uroot    无密码登录以上将密码改为root

  use mysql;

  update user set authentication_string=password('root'),plugin='mysql_native_password' where user='root';

  flush privileges;
6.  vim /etc/mysql/mariadb.conf.d/50-server.cnf  将
skip-grant-tables=1 这句#注释掉
7.    /etc/init.d/mysql stop      /etc/init.d/mysql start
      用mysql -uroot -p 连接,输入root密码

alter user 'root'@'localhost' identified by '123'

mariadb.service

systemctl status mariadb.service

相关文章更多 >

© 2024版权所有 水水网

电话:171780793