新装mysql后登录出现root帐号提示mysql ERROR 1045 (28000): Access denied for use

来源:互联网 发布:逻辑思维 人工智能那期 编辑:程序博客网 时间:2024/04/30 00:24

新装mysql后,首次执行 mysql -uroot -p 后会发现root密码不为空,要重置root密码请参考以下步骤。


编辑mysql配置文件my.ini(如果是my_default.ini请改名为my.ini),在[mysqld]这个条目下加入

  skip-grant-tables
保存退出后重启mysql,点击“开始”->“运行”(快捷键Win+R)。
1.停止:输入 net stop mysql
2.启动:输入 net start mysql


这时候在cmd里面输入mysql -u root -p就可以不用密码登录了,出现password:的时候直接回车可以进入,不会出现ERROR 1045 (28000),但很多操作都会受限制,因为我们不能grant(没有权限)。按下面的流程走:


1.进入mysql数据库:
mysql> use mysql;
Database changed
2.给root用户设置新密码,蓝色部分自己输入:
mysql> update user set authentication_string=password("新密码") where user="root";
Query OK, 1 rows affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
3.刷新数据库
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
4.退出mysql:
mysql> quit

Bye


改好之后,再修改一下my.ini这个文件,把我们刚才加入的"skip-grant-tables"这行删除,保存退出再重启mysql就可以了。


再次重新登录后会提示你 
ERROR 1820 (HY000): You must reset your password using ALTER USER statement befo re executing this statement.
只要输入 set password=password('新密码');即可
0 0