java - 如何为数据库连接创建不同的类

标签 java spring spring-boot datasource

我正在开发一个 spring boot 应用程序,我需要一个通用类来为我提供所有 Controller 的数据库连接,所以我创建了一个单独的类,如下所示:

@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 创建名称时出错。感谢任何帮助

完整堆栈跟踪 Stacktrace

Updated Stack 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'

最佳答案

您不能 Autowiring 静态字段。丑,但如果你想尝试下面的一个

@Component
public class AnotherController {

private static DataBaseConnectionProvider obj;

@Autowired
public void setDataBaseConnectionProvider(DataBaseConnectionProvider obj) {
    AnotherController.obj = obj;
}}

关于java - 如何为数据库连接创建不同的类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45299093/

相关文章:

java - 根据上一个面板中的用户输入显示可变 GUI 面板的建议

java - {{parent.child.0.field}} 它没有解决,如果 child 是 java.util.Set。如果它是 java.util.List 则有效

java - 我应该能够在 Java 正则表达式的单词边界内引用前导或尾随美元符号 ($) 吗?

DelegatingFilterProxy 上的 Spring 和 @Autowired

java - 内部对象的 JSON 到 Java 映射?

java - 为 64 位、32 位、Windows 和 Linux 构建

java - 如何检查spring security中的多个表以进行身份​​验证

spring - 使用 @Value 将属性绑定(bind)到 Grails 中的闭包

spring-boot - IntelliJ Idea + 无法 Autowiring 。找不到类型的 beans

java - Spring Boot graphql 的问题。请求/graphql 结果为 404