Hibernate4 使用Proxool连接数据库出现 at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcSer
2014-10-28 15:41
441 查看
其实只要看第一行就可以了 at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:244) ,就是在配置的时候没取到值。那么为什么没取到值呢,是因为Hibernate默认是使用jdbc方式来取的,如果使用连接池的方式的话,必须告诉Hibernate一声,让它不使用单纯的JDBC连接。加入下面这一句话就可以了。
这问题也困扰了我好几个小时,下面贴出Hibernate的源码来看一下。
package org.hibernate.engine.jdbc.internal;
大家可以看到,参数在取值的时候,它要先用useJdbcMetadata判断一下,是不是JDBC方式,如果不把这个属性设置为false的话,那么取值必然是取不到了,这就是空指针的原因。
PS:以后开源的东西还是要多看看源码
<prop key="hibernate.temp.use_jdbc_metadata_defaults">false</prop>
这问题也困扰了我好几个小时,下面贴出Hibernate的源码来看一下。
package org.hibernate.engine.jdbc.internal;
// 'hibernate.temp.use_jdbc_metadata_defaults' is a temporary magic value. // The need for it is intended to be alleviated with future development, thus it is // not defined as an Environment constant... // // it is used to control whether we should consult the JDBC metadata to determine // certain Settings default values; it is useful to *not* do this when the database // may not be available (mainly in tools usage). final boolean useJdbcMetadata = ConfigurationHelper.getBoolean( "hibernate.temp.use_jdbc_metadata_defaults", configValues, true ); if ( useJdbcMetadata ) { try { final Connection connection = jdbcConnectionAccess.obtainConnection();
大家可以看到,参数在取值的时候,它要先用useJdbcMetadata判断一下,是不是JDBC方式,如果不把这个属性设置为false的话,那么取值必然是取不到了,这就是空指针的原因。
PS:以后开源的东西还是要多看看源码
相关文章推荐
- spring配置出错at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:244
- hibernate4 org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure
- WARN [org.hibernate.engine.jdbc.internal.JdbcServicesImpl] - <HHH000342: Could not obtain connectio
- 使用powerdesigner连接数据库时出现Non SQL Error : Could not load class com.mysql.jdbc.Drive
- 使用powerdesigner连接数据库时出现Non SQL Error : Could not load class com.mysql.jdbc.Drive
- jdbc连接数据库使用sid和service_name的区别
- jdbc连接数据库使用sid和service_name的区别 oracle
- java application应用程序 使用JDBC和proxool两种方式连接数据库 的测试程序代码
- jdbc连接数据库使用sid和service_name的区别
- 使用powerdesigner连接数据库时出现Non SQL Error : Could not load class com.mysql.jdbc.Drive
- tomcat 启动报错, Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment]
- jdbc连接数据库使用sid和service_name的区别
- 使用powerdesigner连接数据库时出现Non SQL Error : Could not load class com.mysql.jdbc.Drive
- jdbc连接数据库使用sid和service_name的区别
- jdbc连接数据库使用sid和service_name的区别
- 基于CDH5.x 下面使用eclipse 操作hive 。使用java通过jdbc连接HIVESERVICE 创建表出现的问题及解决
- JDBC连接数据库使用SERVICE NAME、SID以及TNSName不同写法
- 使用hql使用order by子句出现异常和数据异常的解决办法org.hibernate.hql.internal.ast.QuerySyntaxException
- jdbc连接数据库使用sid和service_name的区别
- Unable to create requested service [org.hibernate.engine.jdbc.env.spi.JdbcEnvironment]