Chinaunix首页 | 论坛 | 博客
  • 博客访问: 33880
  • 博文数量: 10
  • 博客积分: 71
  • 博客等级: 民兵
  • 技术积分: 68
  • 用 户 组: 普通用户
  • 注册时间: 2011-12-08 00:56
文章分类
文章存档

2012年(7)

2011年(3)

我的朋友
最近访客

分类:

2012-01-21 00:36:08

[root@SD]#mysql -u root -p -h 123456
ERROR 1044 (42000): Access denied for user ''@'localhost' to database
原因是OEL5.4禁止localhost访问数据库。
--------------------------------------------------------------------------------------
解决方法一:
更改登陆方式
[root@SD]#mysql -u root -p 123456 -h localhost

解决方法二:
在使用第一种方法登陆上后,执行如下步骤: 
1、select host,user,password from mysql.user;
2、在mysql.user表中添加本地访问数据
grant all privileges on *.* to root@'%' identified by '123456' with grant option;
3、flush privileges;
4、commit;

Reference:
当初次在机器上安装完Mysql时,你可以匿名进行访问数据库或者以不带口令的root身份进入数据库.另外如果你是一个管理员,你还要进行一些用户的建立及授权,这又涉及到设置密码的问题.下面我们就讨论一下如何设置密码: 
  首先我们应该知道Mysql数据库中的口令存储必须用password()函数加密它.因为在user表中是以加密形式存储口令,而不是作为纯文本.如果你没有加密,直接在数据库中执行以下语句: 
  use mysql 
  insert into user (host,user,password) values('%','user_name','your password'); 
  flush privileges; 
  相信结果不会让你满意.因为服务器比较的是加密的值,所以服务器连接一定失败.这里需要说明的是flush privileges;这条命令起到了重新加载授权表.你也可以在shell下直接用mysqladmin -u root reload或者mysqladmin -u root flush-privileges来实现重载授权表. 
  在Mysql环境下,你可以使用以下语句进行设置密码: 
  1.insert into user(host,user,password) values('%','user_name',password("your password"); 
  2.set password for user_name = password("your password") 
  以上两种方法都必须进行重载授权表. 
  3.当然你也可以在创建一个用户时直接设置密码,grant语句将为你自动加密口令. 
  如 
   grant all on *.* to user_name@% identified by "your password"; 
  另外你也可以在shell环境下用mysqladmin程序来设置密码 
  如 
   mysqladmin -u root password "your password" 
  快点去试一下,没问题吧! 




阅读(1228) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~