阅读更多
因为版本更新缘故,之前一些修改数据库密码的方法已经不能适用了。
关于ubuntu mysql5.7 ERROR 1045解决方法如下:
1.修改mysql配置文件,使其可以无密码登录
命令:sudo vim /etc/mysql/my.cnf
在打开此文件后在文件[mysql]下添加:skip-grant-tables
2.重启服务
命令:sudo service mysql restart
3.无密码登录
mysql -uroot -p
4.修改密码
首先:use mysql;
因为当初的(update user set password=password('123') where user='root';)这 个命令已经无法修改密码了。用这个命名会报如下错误:
ERROR 1054 (42S22): Unknown column 'password' in 'field list'
所以笔者找到如下命令:update mysql.user set authentication_string=password('newpassword') where user='root';
*特别注意的一点是:新版的mysql数据库下的user表中已经没有Password字段了
而是将加密后的用户密码存储于authentication_string字段,所以报上面的那个错 误。
flush privileges;
exit;
最后还原配置文件,重启mysql服务(sudo service mysql restart),再重新登录。
关于windows远程设置问题如下:
1.首先运行sudo vim /etc/mysql/mysql.conf.d/mysqld.cnf
在打开文件后,在文件中找到:bind-address = 127.0.0.1这一行,然后注释掉这一行。
然后重启mysql,命令如上个方法。
2.授权用户后才能进行远程连接
mysql -uroot -ppassword进入数据库后运行如下命名:
grant all privileges on *.* to root@"%" identified by "password" with grant option;
flush privileges;
第一行命令解释如下,*.*:第一个*代表数据库名;第二个*代表表名。这里的意思是所有数据库里的所有表都授权给用户。root:授予root账号。“%”:表示授权的用户IP可以指定,这里代表任意的IP地址都能访问MySQL数据库。“password”:分配账号对应的密码,这里密码自己替换成你的mysql root帐号密码。
第二行命令是刷新权限信息。