spring使用DataSoure注入参数时报No supported DataSource type found

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了spring使用DataSoure注入参数时报No supported DataSource type found相关的知识,希望对你有一定的参考价值。

    平常阅读源码什么的没有目的性,所以很少去看什么源码,主要是比较绕看起来吃力,所以一般工作只是找个模版模仿一下。

以上废话,割————————————————————————————————————————————————————————————

    最近照常模仿使用了其它项目里的DataSource用法,代码如下:

    

 1    @Bean
 2     @Primary
 3     @ConfigurationProperties(prefix = "datasource.from")
 4     public DataSource dataSource(){
 5         return DataSourceBuilder.create().build();
 6     }
 7     
 8     @Autowired
 9     @Qualifier("dataSource")
10     private DataSource dataSource;
11 
12     @Bean(name="sqlSessionFactory")
13     public SqlSessionFactory sqlSessionFactory() throws Exception {
14         SqlSessionFactoryBean bean = new SqlSessionFactoryBean();
15         bean.setDataSource(dataSource);
16         bean.setConfigLocation(new ClassPathResource("MybatisConfig.xml"));
17         return bean.getObject();
18     }

    在运行初始化的时候报“No supported DataSource type found”,查找网上资料又说没有指定数据库类型的。

    于是,自己在配置中增加了datasource.from.type=oracle,运行还是报一样的错。于是,到晚上脑子清醒点时,看了下DataSource初始化时的部分源码。

    主要的是第三段代码如下:

1 private static final String[] DATA_SOURCE_TYPE_NAMES = { "org.apache.tomcat.jdbc.pool.DataSource", "com.zaxxer.hikari.HikariDataSource", "org.apache.commons.dbcp.BasicDataSource", "org.apache.commons.dbcp2.BasicDataSource" };
public Class<? extends DataSource> findType(){
    if (this.type != null) {
        return this.type;
    }
    for (String name : DATA_SOURCE_TYPE_NAMES) {
    try {
        return ClassUtils.forName(name, this.classLoader);
    }catch (Exception ex) {}
1  private Class<? extends DataSource> getType() {
2       Class<? extends DataSource> type = findType();
3       if (type != null) {
4         return type;
5       }
6       throw new IllegalStateException("No supported DataSource type found");
7     }
1 public DataSource build() {
2      Class<? extends DataSource> type = getType();
3      DataSource result = (DataSource)BeanUtils.instantiate(type);
4      maybeGetDriverClassName();
5      bind(result);
6      return result;
7    }

    看完上面的代码就明白为什么报错了,就是说在创建DataSource没有找到javax.sql.DataSource的子类,也就是必须要引入DATA_SOURCE_TYPE_NAMES枚举中涉及类的jar包,另外注意引入对应数据库JDBC的jar包。

 

以上,Good lucky!

 

以上是关于spring使用DataSoure注入参数时报No supported DataSource type found的主要内容,如果未能解决你的问题,请参考以下文章

Struts2 Spring JPA 整合时报错:No bean named 'entityManagerFactory' is defined ,请问各位是怎么解决

spring容器注入一个接口的两个实现类

spring.cloud运行时报申请apl失败

随记Spring Data JPA的几个坑

spring依赖注入报错

springMVC 注解 启动时报错