mysql 数据库更改远程访问权限_MySQL, Oracle及数据库讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  MySQL, Oracle及数据库讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 1755 | 回复: 0   主题: mysql 数据库更改远程访问权限        下一篇 
John
注册用户
等级:大元帅
经验:90444
发帖:136
精华:2
注册:2011-7-21
状态:离线
发送短消息息给John 加好友    发送短消息息给John 发消息
发表于: IP:您无权察看 2014-12-19 15:59:26 | [全部帖] [楼主帖] 楼主

最近在调试mysql数据库时,发生以下错误

18:04:45,575 ERROR [STDERR] org.springframework.jdbc.UncategorizedSQLException: Hibernate operation: could not execute query; uncategorized SQLException for SQL [select productlib0_.servicelibvalueid as servicel1_7_, productlib0_.productid as productid7_, productlib0_.servicelibtypeid as servicel3_7_, productlib0_.servicelibid as servicel4_7_ from conferencemanagement.productlibtype productlib0_ where (productlib0_.productid=? )]; SQL state [HY000]; error code [1449]; There is no 'root'@'%' registered; nested exception is java.sql.SQLException: There is no 'root'@'%' registered
18:04:45,577 ERROR [STDERR] Caused by:
18:04:45,577 ERROR [STDERR] java.sql.SQLException: There is no 'root'@'%' registered
18:04:45,578 ERROR [STDERR]         at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:946)
18:04:45,578 ERROR [STDERR]         at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:2985)
18:04:45,578 ERROR [STDERR]         at com.mysql.jdbc.MysqlIO.sendCommand(MysqlIO.java:1631)
18:04:45,578 ERROR [STDERR]         at com.mysql.jdbc.MysqlIO.sqlQueryDirect(MysqlIO.java:1723)
18:04:45,578 ERROR [STDERR]         at com.mysql.jdbc.Connection.execSQL(Connection.java:3283)
18:04:45,578 ERROR [STDERR]         at com.mysql.jdbc.PreparedStatement.executeInternal(PreparedStatement.java:1332)
18:04:45,578 ERROR [STDERR]         at com.mysql.jdbc.PreparedStatement.executeQuery(PreparedStatement.java:1467)


排查错误,最后发现是数据库远程访问权限的问题,使用以下命令即可解决。

1. 登录mysql:mysql -uroot -ppasswd

2. 授权:GRANT ALL PRIVILEGES ON *.* TO'root'@'%'WITH GRANT OPTION //授权任何主机均有访问数据库的权限。

3. 重载权限信息:FLUSH PRIVILEGES //reload the grant tables

4. 退出:quit

另外,搜索到了其他修改方法,如下。

修改mysql数据库的user表

update user set host='%' where user = 'root';
select host, user from user;


--转自 北京联动北方科技有限公司




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论