首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > JAVA > J2EE开发 >

springside4 tomcat上找不到dataSource

2013-01-23 
springside4 tomcat下找不到dataSourceapplicationContext.xml locationclasspath*:/application.proper

springside4 tomcat下找不到dataSource
applicationContext.xml


location="classpath*:/application.properties" />

<!-- 数据源配置, 使用DBCP数据库连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<!-- Connection Info -->
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />

<!-- Connection Pooling Info -->
<property name="maxActive" value="${dbcp.maxActive}" />
<property name="maxIdle" value="${dbcp.maxIdle}" />
<property name="defaultAutoCommit" value="false" />
<!-- 连接Idle一个小时后超时 -->
<property name="timeBetweenEvictionRunsMillis" value="3600000" />
<property name="minEvictableIdleTimeMillis" value="3600000" />
</bean>

<!-- 数据源配置,使用应用服务器的数据库连接池 -->
<!--<jee:jndi-lookup id="dataSource" jndi-name="java:comp/env/jdbc/ExampleDB" />-->
</beans>

<!-- local development环境 -->
<beans profile="development">
<context:property-placeholder ignore-resource-not-found="true"
location="classpath*:/application.properties,
            classpath*:/application.development.properties" />

<!-- DBCP连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="defaultAutoCommit" value="false" />
</bean>
</beans>

<beans profile="functional">
<context:property-placeholder ignore-resource-not-found="true"
location="classpath*:/application.properties,
            classpath*:/application.functional.properties,
            classpath*:/application.functional-local.properties" />

<!-- DBCP连接池 -->
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<property name="defaultAutoCommit" value="false" />
</bean>

<!-- 初始化数据表结构 -->
<jdbc:initialize-database data-source="dataSource" ignore-failures="ALL">
<jdbc:script location="classpath:sql/h2/schema.sql" />
</jdbc:initialize-database>
</beans>

<!-- unit test环境 -->
<beans profile="test">
 <context:property-placeholder ignore-resource-not-found="true"
location="classpath*:/application.properties,
            classpath*:/application.test.properties" />



<!-- 嵌入式内存中数据库 -->
<jdbc:embedded-database id="dataSource" type="H2">
<jdbc:script location="classpath:sql/h2/schema.sql" />
<jdbc:script location="classpath:data/import-data.sql" />
</jdbc:embedded-database>
</beans>
</beans>


调用:
public BeanFactory getBeanFactory() {
BeanFactory bf = new ClassPathXmlApplicationContext(casXml);
return bf;
}

public Connection getConnection() throws SQLException {
BeanFactory bf = getBeanFactory();
DataSource dataSource = (DataSource) bf.getBean("dataSource");
Connection conn = dataSource.getConnection();
return conn;
}

报错:
 org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'org.springframework.dao.annotation.PersistenceExceptionTransla
tionPostProcessor#0': Initialization of bean failed; nested exception is org.springframework.beans.factory.BeanCreationException: Error creating bean
with name 'entityManagerFactory' defined in class path resource [applicationContext.xml]: Cannot resolve reference to bean 'dataSource' while setting
bean property 'dataSource'; nested exception is org.springframework.beans.factory.NoSuchBeanDefinitionException: No bean named 'dataSource' is defined
数据库连接池 dataSource
[解决办法]
dataSource没有定义。先单元测试下,看配置是否成功。顺便看下application.properties的内容。

热点排行