1.修改MySQL的登录设置: 
# vi /etc/my.cnf 
在[mysqld]的段中加上一句:skip-grant-tables 
例如: 
[mysqld] 
datadir=/var/lib/mysql 
socket=/var/lib/mysql/mysql.sock 
skip-grant-tables

保存并且退出vi。

2.重新启动mysqld 

停止 MySQL 数据库

/opt/lampp/lampp stopmysql

只启动 MySQL 数据库

/opt/lampp/lampp startmysql

Stopping MySQL: [ OK ] 
Starting MySQL: [ OK ]

3.登录并修改MySQL的root密码 

# /usr/bin/mysql 
Welcome to the MySQL monitor. Commands end with ; or \g. 
Your MySQL connection id is 3 to server version: 3.23.56 
Type 'help;' or '\h' for help. Type '\c' to clear the buffer. 
mysql> USE mysql ; 
Reading table information for completion of table and column names 
You can turn off this feature to get a quicker startup with -A 
Database changed 
mysql> UPDATE user SET Password = password ('new-password') WHERE User = 'root' ; 
Query OK, 0 rows affected (0.00 sec) 
Rows matched: 2 Changed: 0 Warnings: 0 
mysql> flush privileges ; 
Query OK, 0 rows affected (0.01 sec) 
mysql> quit 
Bye

注意password里面不要有空格

4.将MySQL的登录设置修改回来 
# vi /etc/my.cnf 
将刚才在[mysqld]的段中加上的skip-grant-tables删除 
保存并且退出vi。

5.重新启动mysqld 
# /etc/init.d/mysqld restart 
Stopping MySQL: [ OK ] 
Starting MySQL: [ OK ]

----------------------------------------------------------------------------------------------------------------------------

同时需要支持下mysql远程连接,否则会出现bug:   Host 'XXX' is not allowed to connect to this MySQL server 解决方案/如何开启MySQL的远程帐号

解决方案:

mysql远程连接 Host * is not allowed to connect to this MySQL server

如果mysql不支持远程连接,会出现提示:错误代码是1130,ERROR 1130: Host * is not allowed to connect to this MySQL server ,
 

解决此问题有以下2个方法:

localhost改成%

进入mysql的BIN目录

 代码如下 复制代码

mysql -u root -p

mysql>use mysql;

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

mysql>flush privileges;

具体分析

1、在本机登入mysql后,更改“mysql”数据库里的“user”表里的“host”项,从”localhost”改为'%'。

 代码如下 复制代码
mysql>
mysql>use mysql;
mysql>select 'host' from user where user='root';     

#查看mysql库中的user表的host值(即可进行连接访问的主机/IP名称)

 代码如下 复制代码
mysql>update user set host = '%' where user ='root';

#修改host值(以通配符%的内容增加主机/IP地址,当然也可以直接增加某个特定IP地址,如果执行update语句时出现ERROR 1062 (23000): Duplicate entry '%-root' for key 'PRIMARY' 错误,需要select host from user where user = 'root';
查看一下host是否已经有了%这个值,如果有了直接执行下面的flush privileges;即可)

 代码如下 复制代码

mysql>flush privileges;
mysql>select host,user from user where user='root';
mysql>quit

另一种方法

如果你使用的是phpmyadmin我们可以登录phpmyadmin然后在权限管理中进入,这里会看到所有的用户了,你找到root用户点击修改,然后把域修改成%号即可了(注意,你必须是root权限用户登录哦,否则是不可以修改的)

最新文章

  1. Backbone入门讲解
  2. Arc Engine下数据的加载处理
  3. 安装配置Apache2.4和php7.0
  4. 详解浏览器缓存机制与Apache设置缓存
  5. Qt中QString,int,char,QByteArray之间相互转换
  6. C++中加const与不加const的区别
  7. Bootstrap常用样板
  8. 【java编程】java的关键字修饰符
  9. CentOS 7 lnmp环境配置laravel项目的问题总结!
  10. vue中的axios
  11. SAP自开发程序
  12. Java调用本地命令
  13. Js语言的奇怪特性
  14. windows服务器让WEB通过防火墙的问题
  15. Docker 学习:制作一个dockerfile
  16. 用Python爬下今日头条所有美女,美滋滋!
  17. 根据返回值动态加载select
  18. Linux系统——日志文件
  19. J15W-J45W铜截止阀厂家,J15W-J45W铜截止阀价格 - 专题栏目 - 无极资讯网
  20. filter方法解析

热门文章

  1. LaTex标准article文件框架解析
  2. lintcode-130-堆化
  3. PHP整数取余返回负数解决办法
  4. Linux 项目实用命令
  5. 算法(12)Best Time to Buy and Sell Stock II
  6. iMuseum
  7. 解决微信小程序配置https不成功问题
  8. [洛谷P3521][POI2011]ROT-Tree Rotations
  9. [TJOI2018]数学计算 线段树
  10. Windows Socket 编程_ 简单的服务器/客户端程序