日常阅读源码什么的没有目的性,因此不多去看什么源码,主要是比较绕看起来吃力,因此通常工做只是找个模版模仿一下。java
以上废话,割————————————————————————————————————————————————————————————sql
最近照常模仿使用了其它项目里的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”,查找网上资料又说没有指定数据库类型的。apache
因而,本身在配置中增长了datasource.from.type=oracle,运行仍是报同样的错。因而,到晚上脑子清醒点时,看了下DataSource初始化时的部分源码。tomcat
主要的是第三段代码以下:oracle
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包。ui
以上,Good lucky!this