出错with root cause

【背景:】

  我自己写了一个项目,主页可以看到一个数据库里的一个应用的users用户表的所有数据,包括用户的年龄,姓名,出生日期等信息。后来又想再增加一个注册功能,写好了之后进行单元测试,结果就出现了with root cause的错误,找了一个遍,才找到了原因。

  首先,我安装的数据库mysql中的user都是默认的一共四个用户。分别是:

localhostroot
127.0.0.1root
::1root
localhost 

( 前四列:Host、User、Password,分别表示主机名、用户名和密码Host和User列为user表的联合主键,当用户与服务器建立连接时,输入的用户名、主机名和密码必须匹配user表中对应的字段,只有这三个值,都匹配的时候,才允许建立连接。 当修改密码时,只需要修改user表中Password字段的值。这些用户开始都是没有设置密码的,并且权限也不同,前三个用户都是root用户,拥有数据库的大多数权限,包括增删改查等,而最后一个用户的没有数据库的任何权限。开始的时候,我写的查询就是没有密码的,链接数据库的时候,直接

driver="com.mysql.jdbc.Driver";
url="jdbc:mysql://localhost:3306/test";
user="root";
password="";

DriverManager.getConnection(driver,url,user,password);

  经过试验发现这样只能获取到数据库里面的数据,但是不能对数据库进行程序上的操作,于是我在数据库中执行了以下操作,将所有用户的密码设置为了root。

update user set  password="root"; 结果这样之后数据库用root 用户和root密码都登陆不了了,这样就出现了我之前写的那个数据库连接失败的博客的现象,最后找到了一个完美修改数据库默认密码的方法,只需要

【步骤】

1.打开dos界面

2.进入到mysql的安装目录的bin

3.mysql -u [你的用户一般用root] -p回车

4.系统会提示你输入密码,如果一开始就是没有密码的,直接回车可以进入,

5.mysql>use mysql

6. mysql>update user set password=PASSWORD("root") where user="root"

7.最关键的一步:flush privileges;刷新MySQL的系统权限相关表,否则会出现拒绝访问。这一步才是关键所在啊,之前就是不知道这一步,导致很多地方出错,搞不明白。

7.exit 回车退出mysql>

 Access denied for user 'root'@'localhost' (using password: YES)这个问题有时也是因为数据库默认密码为空导致的,可以按照上面的步骤试试。

这样之后就可以完美的通过java程序来操作数据库了,完美收工!

 

 

转载于:https://www.cnblogs.com/liuyongbo/p/8196072.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值