spring配置出错at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java:244
1.SSM集成:
spring 4.0.5
hibernate 4.3.1;
sessionFactory 注入datasource
-
<bean id="sf" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
-
<property name="dataSource" ref="myDataSource" />
-
<property name="packagesToScan">
-
<list>
-
<value>xx.xx.model </value>
-
</list>
-
</property>
-
<property name="hibernateProperties">
-
<props>
-
<prop key="hibernate.dialect">
-
org.hibernate.dialect.Oracle9Dialect
-
</prop>
-
<prop key="hibernate.show_sql">true </prop>
-
</props>
-
</property>
-
</bean>
2.出错:
-
INFO: HCANN000001: Hibernate Commons Annotations { 4.0.4.Final}
-
2016- 5- 19 22: 38: 58 org.hibernate.Version logVersion
-
INFO: HHH000412: Hibernate Core { 4.3.1.Final}
-
2016- 5- 19 22: 38: 58 org.hibernate.cfg.Environment <clinit>
-
INFO: HHH000206: hibernate.properties not found
-
2016- 5- 19 22: 38: 58 org.hibernate.cfg.Environment buildBytecodeProvider
-
INFO: HHH000021: Bytecode provider name : javassist
-
2016- 5- 19 22: 38: 58 org.hibernate.engine.jdbc.internal.JdbcServicesImpl configure
-
WARN: HHH000341: Could not obtain connection metadata : 不支持的特性
-
2016- 5- 19 22: 38: 58 org.hibernate.engine.jdbc.internal.LobCreatorBuilder useContextualLobCreation
-
INFO: HHH000422: Disabling contextual LOB creation as connection was null
-
2016- 5- 19 22: 38: 58 org.springframework.web.context.ContextLoader initWebApplicationContext
-
严重: Context initialization failed
-
org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'sf' defined in ServletContext resource [/WEB-INF/applicationContext.xml]: Invocation of init method failed; nested exception is java.lang.NullPointerException
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java: 1553)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java: 539)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java: 475)
-
at org.springframework.beans.factory.support.AbstractBeanFactory$ 1.getObject(AbstractBeanFactory.java: 304)
-
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java: 228)
-
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java: 300)
-
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java: 195)
-
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java: 684)
-
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java: 760)
-
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java: 482)
-
at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java: 403)
-
at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java: 306)
-
at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java: 106)
-
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java: 5003)
-
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java: 5517)
-
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java: 150)
-
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java: 901)
-
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java: 877)
-
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java: 652)
-
at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java: 1263)
-
at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java: 1978)
-
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java: 439)
-
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java: 303)
-
at java.util.concurrent.FutureTask.run(FutureTask.java: 138)
-
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java: 895)
-
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java: 918)
-
at java.lang.Thread.run(Thread.java: 662)
-
Caused by: java.lang.NullPointerException
-
at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java: 244)
-
at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java: 89)
-
at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java: 206)
-
at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java: 178)
-
at org.hibernate.cfg.Configuration.buildTypeRegistrations(Configuration.java: 1885)
-
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java: 1843)
-
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java: 1928)
-
at org.springframework.orm.hibernate4.LocalSessionFactoryBuilder.buildSessionFactory(LocalSessionFactoryBuilder.java: 343)
-
at org.springframework.orm.hibernate4.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java: 431)
-
at org.springframework.orm.hibernate4.LocalSessionFactoryBean.afterPropertiesSet(LocalSessionFactoryBean.java: 416)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java: 1612)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java: 1549)
-
... 26 more
-
2016- 5- 19 22: 38: 58 org.apache.catalina.core.StandardContext listenerStart
-
严重: Exception sending context initialized event to listener instance of class org.springframework.web.context.ContextLoaderListener
-
org. springframework. beans. factory. BeanCreationException: Error creating bean with name ' sf' defined in ServletContext resource [/ WEB- INF/ applicationContext. xml]: Invocation of init method failed; nested exception is java.lang.NullPointerException
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java: 1553)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java: 539)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java: 475)
-
at org.springframework.beans.factory.support.AbstractBeanFactory$ 1.getObject(AbstractBeanFactory.java: 304)
-
at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java: 228)
-
at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java: 300)
-
at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java: 195)
-
at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java: 684)
-
at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java: 760)
-
at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java: 482)
-
at org.springframework.web.context.ContextLoader.configureAndRefreshWebApplicationContext(ContextLoader.java: 403)
-
at org.springframework.web.context.ContextLoader.initWebApplicationContext(ContextLoader.java: 306)
-
at org.springframework.web.context.ContextLoaderListener.contextInitialized(ContextLoaderListener.java: 106)
-
at org.apache.catalina.core.StandardContext.listenerStart(StandardContext.java: 5003)
-
at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java: 5517)
-
at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java: 150)
-
at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java: 901)
-
at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java: 877)
-
at org.apache.catalina.core.StandardHost.addChild(StandardHost.java: 652)
-
at org.apache.catalina.startup.HostConfig.deployDirectory(HostConfig.java: 1263)
-
at org.apache.catalina.startup.HostConfig$DeployDirectory.run(HostConfig.java: 1978)
-
at java.util.concurrent.Executors$RunnableAdapter.call(Executors.java: 439)
-
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java: 303)
-
at java.util.concurrent.FutureTask.run(FutureTask.java: 138)
-
at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java: 895)
-
at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java: 918)
-
at java.lang.Thread.run(Thread.java: 662)
-
Caused by: java.lang.NullPointerException
-
at org.hibernate.engine.jdbc.internal.JdbcServicesImpl.configure(JdbcServicesImpl.java: 244)
-
at org.hibernate.boot.registry.internal.StandardServiceRegistryImpl.configureService(StandardServiceRegistryImpl.java: 89)
-
at org.hibernate.service.internal.AbstractServiceRegistryImpl.initializeService(AbstractServiceRegistryImpl.java: 206)
-
at org.hibernate.service.internal.AbstractServiceRegistryImpl.getService(AbstractServiceRegistryImpl.java: 178)
-
at org.hibernate.cfg.Configuration.buildTypeRegistrations(Configuration.java: 1885)
-
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java: 1843)
-
at org.hibernate.cfg.Configuration.buildSessionFactory(Configuration.java: 1928)
-
at org.springframework.orm.hibernate4.LocalSessionFactoryBuilder.buildSessionFactory(LocalSessionFactoryBuilder.java: 343)
-
at org.springframework.orm.hibernate4.LocalSessionFactoryBean.buildSessionFactory(LocalSessionFactoryBean.java: 431)
-
at org.springframework.orm.hibernate4.LocalSessionFactoryBean.afterPropertiesSet(LocalSessionFactoryBean.java: 416)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.invokeInitMethods(AbstractAutowireCapableBeanFactory.java: 1612)
-
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.initializeBean(AbstractAutowireCapableBeanFactory.java: 1549)
-
... 26 more
-
-
3.查了半天也没发现问题在哪里,
后来看到了一位博友博文: http://blog.youkuaiyun.com/luxiaoshuai/article/details/40540929
原来是使用连接池注入的数据源 需要添加如下一条属性:
<prop key="hibernate.temp.use_jdbc_metadata_defaults">false</prop>
配置如下:
-
<bean id="sf"
-
class= "org.springframework.orm.hibernate4.LocalSessionFactoryBean">
-
<property name="dataSource" ref="myDataSource" />
-
<property name="packagesToScan">
-
<list>
-
<value>xx.xx.model </value>
-
</list>
-
</property>
-
<property name="hibernateProperties">
-
<props>
-
<prop key="hibernate.dialect">
-
org.hibernate.dialect.Oracle9Dialect
-
</prop>
-
<prop key="hibernate.show_sql">true </prop>
-
<!-- 重要: 使用连接池设置false -->
-
<prop key="hibernate.temp.use_jdbc_metadata_defaults">false </prop>
-
</props>
-
</property>
-
</bean>
添加上以后,问题立马解决!
以后还是要多看源码啊.