启动项目,报错:org.hibernate.service.UnknownUnwrapTypeException: Cannot unwrap to requested type [javax.sql.DataSource]。也就是说,不能打开数据源。可是我在Hibernate的配置文件中明明配置了数据源了啊。原来应该由Spring来管理数据源,而Hibernate只需要管理OR-Mapping就可以了。于是将Hibernate的数据源删除,在Spring中配置。代码如下:
1 <bean id="dataSource" 2 class="org.apache.commons.dbcp.BasicDataSource" abstract="false" 3 lazy-init="default" autowire="default" destroy-method="close"> 4 <property name="driverClassName" value="com.mysql.jdbc.Driver"><!-- 设置数据库的驱动 --> 5 </property> 6 <property name="url" 7 value="jdbc:mysql://localhost:3306/db_project"><!--设置数据库的地址 --> 8 </property> 9 <property name="username" value="root"></property><!-- 设置用户名 --> 10 <property name="password" value="111"></property><!-- 设置密码 --> 11 </bean>
然后将dataSource注入到sessionFactory中。代码如下:
1 <bean id="sessionFactory" 2 class="org.springframework.orm.hibernate4.LocalSessionFactoryBean"> 3 <property name="configLocation" 4 value="classpath:hibernate.cfg.xml"> 5 </property> 6 7 <property name="dataSource" ref="dataSource"></property> 8 </bean>
org.springframework.orm.hibernate4.LocalSessionFactoryBean这个类中有相应的dataSource的setter方法,因此按照上述进行配置,就可以了。
然后将Hibernate配置文件中关于数据源的属性全部删除,这个问题就解决了。