当前位置: 首页> 健康> 母婴 > druid连接gbase8s数据库报错空指针

druid连接gbase8s数据库报错空指针

时间:2025/7/10 21:04:30来源:https://blog.csdn.net/wangyx01/article/details/142071200 浏览次数:0次

在使用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);

关键字:druid连接gbase8s数据库报错空指针

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: