关于 ubuntu mysql5.7 ERROR 1045解决办法及windows远程ubuntu设置等一些问题

    因为版本更新缘故,之前一些修改数据库密码的方法已经不能适用了。

    关于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帐号密码。

               第二行命令是刷新权限信息。

         























猜你喜欢

转载自zfy163520.iteye.com/blog/2363680