Failed to convert property value of type [org.apache.commons.dbcp.BasicDataSource] to required

org.springframework.beans.factory.BeanCreationException: Error creating bean with name 'userDAO' defined in class path resource [beans.xml]: Initialization of bean failed; nested exception is org.springframework.beans.TypeMismatchException: Failed to convert property value of type [org.springframework.jdbc.datasource.DriverManagerDataSource] to required type [com.springsource.tcserver.serviceability.request.DataSource] for property 'dataSource'; nested exception is java.lang.IllegalArgumentException: Cannot convert value of type [org.springframework.jdbc.datasource.DriverManagerDataSource] to required type [com.springsource.tcserver.serviceability.request.DataSource] for property 'dataSource': no matching editors or conversion strategy found
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:478)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory$1.run(AbstractAutowireCapableBeanFactory.java:409)
	at java.security.AccessController.doPrivileged(Native Method)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.createBean(AbstractAutowireCapableBeanFactory.java:380)
	at org.springframework.beans.factory.support.AbstractBeanFactory$1.getObject(AbstractBeanFactory.java:264)
	at org.springframework.beans.factory.support.DefaultSingletonBeanRegistry.getSingleton(DefaultSingletonBeanRegistry.java:220)
	at org.springframework.beans.factory.support.AbstractBeanFactory.doGetBean(AbstractBeanFactory.java:261)
	at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:185)
	at org.springframework.beans.factory.support.AbstractBeanFactory.getBean(AbstractBeanFactory.java:164)
	at org.springframework.beans.factory.support.DefaultListableBeanFactory.preInstantiateSingletons(DefaultListableBeanFactory.java:429)
	at org.springframework.context.support.AbstractApplicationContext.finishBeanFactoryInitialization(AbstractApplicationContext.java:729)
	at org.springframework.context.support.AbstractApplicationContext.refresh(AbstractApplicationContext.java:381)
	at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:139)
	at org.springframework.context.support.ClassPathXmlApplicationContext.<init>(ClassPathXmlApplicationContext.java:83)
	at com.spring.jdbcTest.jdbcTest.test(jdbcTest.java:20)
	at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
	at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
	at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
	at java.lang.reflect.Method.invoke(Method.java:601)
	at org.junit.runners.model.FrameworkMethod$1.runReflectiveCall(FrameworkMethod.java:44)
	at org.junit.internal.runners.model.ReflectiveCallable.run(ReflectiveCallable.java:15)
	at org.junit.runners.model.FrameworkMethod.invokeExplosively(FrameworkMethod.java:41)
	at org.junit.internal.runners.statements.InvokeMethod.evaluate(InvokeMethod.java:20)
	at org.junit.runners.BlockJUnit4ClassRunner.runNotIgnored(BlockJUnit4ClassRunner.java:79)
	at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:71)
	at org.junit.runners.BlockJUnit4ClassRunner.runChild(BlockJUnit4ClassRunner.java:49)
	at org.junit.runners.ParentRunner$3.run(ParentRunner.java:193)
	at org.junit.runners.ParentRunner$1.schedule(ParentRunner.java:52)
	at org.junit.runners.ParentRunner.runChildren(ParentRunner.java:191)
	at org.junit.runners.ParentRunner.access$000(ParentRunner.java:42)
	at org.junit.runners.ParentRunner$2.evaluate(ParentRunner.java:184)
	at org.junit.runners.ParentRunner.run(ParentRunner.java:236)
	at org.eclipse.jdt.internal.junit4.runner.JUnit4TestReference.run(JUnit4TestReference.java:50)
	at org.eclipse.jdt.internal.junit.runner.TestExecution.run(TestExecution.java:38)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:459)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.runTests(RemoteTestRunner.java:675)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.run(RemoteTestRunner.java:382)
	at org.eclipse.jdt.internal.junit.runner.RemoteTestRunner.main(RemoteTestRunner.java:192)
Caused by: org.springframework.beans.TypeMismatchException: Failed to convert property value of type [org.springframework.jdbc.datasource.DriverManagerDataSource] to required type [com.springsource.tcserver.serviceability.request.DataSource] for property 'dataSource'; nested exception is java.lang.IllegalArgumentException: Cannot convert value of type [org.springframework.jdbc.datasource.DriverManagerDataSource] to required type [com.springsource.tcserver.serviceability.request.DataSource] for property 'dataSource': no matching editors or conversion strategy found
	at org.springframework.beans.BeanWrapperImpl.convertForProperty(BeanWrapperImpl.java:391)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.convertForProperty(AbstractAutowireCapableBeanFactory.java:1287)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.applyPropertyValues(AbstractAutowireCapableBeanFactory.java:1248)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.populateBean(AbstractAutowireCapableBeanFactory.java:1008)
	at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:470)
	... 37 more
Caused by: java.lang.IllegalArgumentException: Cannot convert value of type [org.springframework.jdbc.datasource.DriverManagerDataSource] to required type [com.springsource.tcserver.serviceability.request.DataSource] for property 'dataSource': no matching editors or conversion strategy found
	at org.springframework.beans.TypeConverterDelegate.convertIfNecessary(TypeConverterDelegate.java:219)
	at org.springframework.beans.TypeConverterDelegate.convertIfNecessary(TypeConverterDelegate.java:138)
	at org.springframework.beans.BeanWrapperImpl.convertForProperty(BeanWrapperImpl.java:386)
	... 41 more

原因是引入包出错:

在UserDAOImpl中使用

public void setDataSource(DataSource dataSource){
		this.jdbcTemplate=new JdbcTemplate(dataSource);
		this.namedParameterJdbc=new NamedParameterJdbcTemplate(dataSource);
		this.simpleJdbcTemplate=new SimpleJdbcTemplate(dataSource);
	}

引入DataSource类出错:

import sun.jdbc.odbc.ee.DataSource;

正确的应该是:
import javax.sql.DataSource;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: org.apache.commons.dbcp2.basicdatasourceApache Commons DBCP 2.x中的一个类,它是一个基本的数据源实现,用于管理数据库连接池。它提供了一些配置选项,例如最大连接数、最小空闲连接数、连接超时时间等,可以根据应用程序的需要进行配置。使用这个类可以有效地管理数据库连接,提高应用程序的性能和可靠性。 ### 回答2: org.apache.commons.dbcp2.basicdatasource是一个用于管理数据库连接池的类,它是Apache Commons DBCP项目的一部分。 在开发中,数据库连接的创建和关闭是非常耗费资源的操作。为了提高效率和性能,可以使用连接池来管理数据库连接。连接池是一组已经创建的数据库连接对象,可以被重复使用,避免了重复创建和关闭连接的开销。 org.apache.commons.dbcp2.basicdatasource提供了一些方法来配置和管理连接池。通过设置一些属性,比如最大连接数、最小空闲连接数、最大等待时间等,可以调整连接池的行为,以满足应用程序的需求。 使用org.apache.commons.dbcp2.basicdatasource时,首先需要创建一个BasicDataSource对象,并配置所需的属性。然后,可以通过调用getConnection()方法从连接池中获取一个数据库连接。使用完连接后,可以通过调用close()方法将连接返回给连接池。 此外,org.apache.commons.dbcp2.basicdatasource还提供了一些其他的方法,用于监控和管理连接池的状态。例如,可以通过getNumActive()方法获得当前正在使用的连接数,通过getNumIdle()方法获得当前空闲的连接数。 总之,org.apache.commons.dbcp2.basicdatasource是一个功能强大的类,可以帮助我们更有效地管理数据库连接,提高应用程序的性能和效率。 ### 回答3: org.apache.commons.dbcp2.BasicDataSource是一个Java类库中的数据库连接池实现。它是Apache Commons项目的一部分,旨在提供简单易用的数据库连接池功能。 这个类提供了一组方法来管理数据库连接的获取和释放。它可以配置最大活动连接数、最大闲置连接数、初始连接数和连接等待超时时间等属性。 使用BasicDataSource,我们可以通过调用其getConnection()方法来获取数据库连接。当我们不再需要连接时,可以通过调用连接的close()方法将其释放回数据库连接池。这样可以减少每次数据库操作都需要建立和关闭连接的开销,提高性能。此外,连接池还可以防止数据库资源被过度占用,以及更好地管理连接的生命周期。 BasicDataSource基于"DataSource"接口的标准实现,所以它可以与任何支持"DataSource"接口的数据库驱动器一起使用。它支持常见的数据库连接池特性,如连接重用、连接验证和连接泄漏检查。此外,它还支持事务隔离级别和只读模式等更高级的功能。 总结而言,org.apache.commons.dbcp2.BasicDataSource提供了一个可配置和易于使用的数据库连接池实现。它可以提高数据库连接的获取和释放效率,减少资源占用,适用于各种数据库操作场景。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值