java – 如何为数据库连接创建不同的类
发布时间:2020-12-15 04:39:49 所属栏目:Java 来源:网络整理
导读:我正在开发一个 Spring启动应用程序,我需要一个通用类来为我提供所有控制器的数据库连接所以我创建了一个sepeate类如下: @RestControllerpublic class DataBaseConnector{ @Autowired @Qualifier("dataSource") public static DataSource dataSource; @Bean
我正在开发一个
Spring启动应用程序,我需要一个通用类来为我提供所有控制器的数据库连接所以我创建了一个sepeate类如下:
@RestController public class DataBaseConnector{ @Autowired @Qualifier("dataSource") public static DataSource dataSource; @Bean @Primary @ConfigurationProperties(prefix = "spring.ds") public DataSource DataSourcePGStreet() { return DataSourceBuilder.create().build(); } @Autowired public Connection giveConnection() throws SQLException{ return dataSource.getConnection(); } } 然后在另一个Controller中,我调用如下连接: @Autowired @Qualifier("dbc") private static DataBaseConnector obj; @Autowired private Connection connectionDatabase; .../// Rest Code @RequestMapping(value="/path",produces={MediaType.APPLICATION_JSON_VALUE},method=RequestMethod.GET) public ResponseEntity<?> getStreetScore(){ obj=new DataBaseConnector(); connectionDatabase=obj.giveConnection(); } 但这让我错了 使用DataBaseConnector.Any帮助创建名称时出错感谢 全栈Trace 描述: Field dataSource in com.dmmltasmu.controller.DataBaseConnector required a bean of type 'javax.sql.DataSource' that could not be found. - Bean method 'dataSource' not loaded because @ConditionalOnClass did not find required class 'org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType' - Bean method 'dataSource' not loaded because @ConditionalOnClass did not find required classes 'javax.transaction.TransactionManager','org.springframework.jdbc.datasource.embedded.EmbeddedDatabaseType' 解决方法
您无法自动装配静态字段.丑陋,但如果你想尝试低于一个
@Component public class AnotherController { private static DataBaseConnectionProvider obj; @Autowired public void setDataBaseConnectionProvider(DataBaseConnectionProvider obj) { AnotherController.obj = obj; }} (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |