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!
文章来自:http://www.cnblogs.com/knowledgebird/p/5251925.html