在使用druid 1.2.17以及之后版本中,在连接gbase8s数据库时报错空指针
java.lang.NullPointerException
at com.alibaba.druid.pool.DruidAbstractDataSource.createPhysicalConnection(DruidAbstractDataSource.java:1764)
at com.alibaba.druid.pool.DruidDataSource.init(DruidDataSource.java:939)
at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:1463)
at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:1459)
at com.alibaba.druid.pool.DruidDataSource.getConnection(DruidDataSource.java:83)
原因在获取数据库类型(dbTypeName)时不支持gbase8s数据库,导致获取类型为null,然后在createPhysicalConnection 中构建数据库连接时直接使用dbTypeName.equals做判断,导致此处空指针,异常传递到上层最终报错空指针
else if (dbTypeName.equals(DbType.sqlserver.name())) {
个人觉得这块代码处理的不太合适,如果要限制数据库类型可以有很多地方或者办法能处理,在前边获取到 dbTypeName =null 就应该给出日志结束调用,而不是在后边突兀的一个空指针异常
解决方案
1 在com.alibaba.druid.util.JdbcUtils的getDriverClassName方法中加入gbase8s支持
else if (rawUrl.startsWith("jdbc:gbasedbt-sqli:")) {
return "com.gbasedbt.jdbc.Driver";
}
2 在com.alibaba.druid.util.JdbcUtils的getDbTypeRaw方法加入gbase8s支持
else if (rawUrl.startsWith("jdbc:gbasedbt-sqli:") ) {
return DbType.gbase8s;
}
3 在com.alibaba.druid枚举类 DbType 中加入gbase8s支持
gbase8s(0);