bitronix 连接 MySQL 出现MySQLSyntaxErrorException 的解决方法

1. 开发环境

hibernate 版本:5.1.0.Final
Bitronix btm 版本:2.1.3

2 异常堆栈信息

Caused by: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: Access denied for user ''@'localhost' to database 'hibernate'  at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)  at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)  at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)  at java.lang.reflect.Constructor.newInstance(Constructor.java:423)  at com.mysql.jdbc.Util.handleNewInstance(Util.java:377)  at com.mysql.jdbc.Util.getInstance(Util.java:360)  at com.mysql.jdbc.SQLError.createSQLException(SQLError.java:978)  at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3887)  at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:3823)  at com.mysql.jdbc.MysqlIO.checkErrorPacket(MysqlIO.java:870)  at com.mysql.jdbc.MysqlIO.proceedHandshakeWithPluggableAuthentication(MysqlIO.java:1659)  at com.mysql.jdbc.MysqlIO.doHandshake(MysqlIO.java:1206)  at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2234)  at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2265)  at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2064)  at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:790)  at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:44)  at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method)  at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62)  at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45)  at java.lang.reflect.Constructor.newInstance(Constructor.java:423)  at com.mysql.jdbc.Util.handleNewInstance(Util.java:377)  at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:395)  at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:325)  at bitronix.tm.resource.jdbc.lrc.LrcXADataSource.getXAConnection(LrcXADataSource.java:104)  ... 33 more

很明显是因为没有访问 MySQL 数据库的权限,导致访问被拒绝。

打开代码一看,果然是这样,代码里没有提供访问数据库的账号和密码嘛

ds.setClassName("bitronix.tm.resource.jdbc.lrc.LrcXADataSource");          ds.getDriverProperties().put(              "url",              connectionURL != null ? connectionURL                  : "jdbc:mysql://localhost:3306/hibernate?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull"          );          Properties dp=ds.getDriverProperties();          dp.put("driverClassName", "com.mysql.jdbc.Driver");          ds.setDriverProperties(dp);

赶紧加上,问题解决 O(∩_∩)O~

...dp.put("user","root");dp.put("password","");...ds.setDriverProperties(dp);

更多相关文章

  1. android中HttpURLConnection调用getResponseCode()时崩溃 解决方
  2. Android空引用问题的解决方法——on a null object reference
  3. android读取assets大于1M文件的解决方法
  4. 几个Android小错误解决方法
  5. CheckBox android:paddingLeft 不兼容问题解决方法
  6. Android(安卓)Studio使用过程中遇到的问题(一)-- "value 2"异常解
  7. Eclipse中编译Android工程时出现的问题解决方法。
  8. Android(安卓)ListView滑动后背景变黑问题解决方法
  9. Android(安卓)ListView滑动后背景变黑问题解决方法

随机推荐

  1. Android培训HandlerThread的使用及源码解
  2. Android(安卓)Handler机制
  3. 项目运行报错Error: Static interface me
  4. webView 的深入研究
  5. 【Android】IPC(进程间通信)
  6. Android中有关数据库SQLite的介绍
  7. android 使用Maven多项目搭建纪要
  8. android背景选择器selector用法小结
  9. Android轮询机制
  10. 认识Gradle