在ubuntu系统通过apt-get 安装好mysql 并且配置好密码后, 使用这个命令“mysql -uroot -pmyadmin”后出现以下错误:
“Access denied for user 'root'@'localhost' (using password:YES)”
直接输入“mysql” 也回报类似的错误:应该是:
“Access denied for user 'ODBC'@'localhost' (using password:NO)”。
关于这个问题,在网上找了一些解决方案(这个链接地址还比较不错https://www.cnblogs.com/qq78292959/p/3641972.html),也换了盘符重装了好几次,问题依旧。
有网上说打开MySQL 的 MySQL 5.5 Command Line Client,在里面进行一系列的操作即可。但是此界面进来就要输入密码:
(BTW, 尝试重装在安装MySQL的时候不设置密码。安装成功后,还是一样报错!)
网上看了一大堆的解决办法,都不行。最后,结合上面的文章和其他一些文章,终于解决问题了, 也不知道是不是最好解决手段. 欢迎"大家"之言!
解决步骤:
1、打开MySQL目录下的配置文件(我的目录是/etc/mysql/mysql.conf.d/mysqld.cnf, 可能有的系统是my.ini),在文件的最后添加一行“skip-grant-tables”,保存并关闭文件。
2、重启MySQL服务(我用命令 service mysql restart)。
3、在命令行中输入“mysql -uroot -p”(不输入密码),回车即可进入数据库。
4、执行,“use mysql;”使用mysql数据库。
5、执行,“update user set authentication_string=PASSWORD("rootadmin") where user='root';”(修改root的密码, 有的mysql表列名可能是password, 需要是命令:"update user set password=PASSWORD("rootadmin") where user='root';")
6、打开MySQL目录下的my.ini文件,删除最后一行的“skip-grant-tables”,保存并关闭文件。
7、重启MySQL服务。( service mysql restart)
8、在命令行中输入“mysql -uroot -prootadmin”,问题搞定!