Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/spring/11.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 即使在使用限定符之后,也无法自动连接相同类型但名称不同的2个bean_Java_Spring_Autowired - Fatal编程技术网

Java 即使在使用限定符之后,也无法自动连接相同类型但名称不同的2个bean

Java 即使在使用限定符之后,也无法自动连接相同类型但名称不同的2个bean,java,spring,autowired,Java,Spring,Autowired,我正在开发一个spring启动应用程序,我有一个配置类,在这个类中我定义了两个类型相同但名称不同的bean,我使用这个bean作为另一个bean的参数,我使用限定符来定义不同的名称,但我仍然无法自动连接这个bean import com.typesafe.config.Config; import com.typesafe.config.ConfigFactory; import org.springframework.beans.factory.annotation.Qualifier; im

我正在开发一个spring启动应用程序,我有一个配置类,在这个类中我定义了两个类型相同但名称不同的bean,我使用这个bean作为另一个bean的参数,我使用限定符来定义不同的名称,但我仍然无法自动连接这个bean

import com.typesafe.config.Config;
import com.typesafe.config.ConfigFactory;
import org.springframework.beans.factory.annotation.Qualifier;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.jdbc.core.JdbcTemplate;
import org.springframework.jdbc.datasource.DriverManagerDataSource;

import javax.sql.DataSource;
import java.io.File;

/**
 * Created by jauharia on 6/28/2017.
 */
@Configuration
public class DbConfig {

    @Bean(name = "sourceJdbcTemplate")
    public JdbcTemplate sourceJdbcTemple(@Qualifier("srcDataSource") DataSource dataSource) {
        return new JdbcTemplate(dataSource);
    }


    @Bean(name = "srcDataSource")
    public DataSource sourceDataSource(Config config) {
        String driverClassName = config.getString("dbPullConfig.Database.Source.driver");
        String url = config.getString("dbPullConfig.Database.Source.url");
        String userName = config.getString("dbPullConfig.Database.Source.username");
        String password = config.getString("dbPullConfig.Database.Source.password");

        DriverManagerDataSource driverManagerDataSource = new DriverManagerDataSource();
        driverManagerDataSource.setDriverClassName(driverClassName);
        driverManagerDataSource.setUrl(url);
        driverManagerDataSource.setUsername(userName);
        driverManagerDataSource.setPassword(password);

        return driverManagerDataSource;
    }

    @Bean(name = "destDataSource")
    public DataSource destinationDataSource(Config config) {
        String driverClassName = config.getString("dbPullConfig.Database.Destination.driver");
        String url = config.getString("dbPullConfig.Database.Destination.url");
        String userName = config.getString("dbPullConfig.Database.Destination.username");
        String password = config.getString("dbPullConfig.Database.Destination.password");

        DriverManagerDataSource driverManagerDataSource = new DriverManagerDataSource();
        driverManagerDataSource.setDriverClassName(driverClassName);
        driverManagerDataSource.setUrl(url);
        driverManagerDataSource.setUsername(userName);
        driverManagerDataSource.setPassword(password);

        return driverManagerDataSource;
    }

    @Bean(name = "config")
    public Config config() {
        return ConfigFactory.parseFile(new File("DbPullConfig.conf"));
    }
}
我得到了下面的错误

parameter 0 of method sourceJdbcTemple in com.ambuj.risk.DbConfig required a single bean, but 2 were found:
    - srcDataSource: defined by method 'sourceDataSource' in class path resource [com/ambuj/risk/DbConfig.class]
    - destDataSource: defined by method 'destinationDataSource' in class path resource [com/ambuj/risk/DbConfig.class]
pom如下所示

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">

    <modelVersion>4.0.0</modelVersion>

    <artifactId>DbPull</artifactId>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>1.5.3.RELEASE</version>
    </parent>

    <dependencies>
        <dependency>
            <groupId>com.typesafe</groupId>
            <artifactId>config</artifactId>
            <version>1.3.1</version>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-jdbc</artifactId>
        </dependency>
        <dependency>
            <groupId>com.sybase.jconnect</groupId>
            <artifactId>jconn4</artifactId>
            <version>7.0</version>
        </dependency>

        <dependency>
            <groupId>commons-dbcp</groupId>
            <artifactId>commons-dbcp</artifactId>
            <version>1.4</version>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>
</project>

4.0.0
DbPull
org.springframework.boot
spring启动程序父级
1.5.3.1发布
com.typesafe
配置
1.3.1
org.springframework.boot
SpringBootStarterWeb
org.springframework.boot
弹簧靴起动器执行器
org.springframework.boot
弹簧起动试验
测试
org.springframework.boot
弹簧靴启动器jdbc
com.sybase.jconnect
jconn4
7
公共dbcp
公共dbcp
1.4
org.springframework.boot
springbootmaven插件

use@primary annotation,它主要用于您的项目中您使用的是哪个版本的Spring?这看起来是正确的。还请注意,您可以在同一配置类上的
@Bean
方法中使用方法调用
sourceDataSource()
,这对于您的情况可能已经足够了。@AmbujJauhari您还可以包括导入语句吗?我能想到的唯一一种情况是,您正在使用其他库(如javax.inject.Qualifier)中的限定符注释。@KalaiselvanA是一种将数据从1数据库复制到另一数据库的工具,在大多数情况下,我们都有源和目标数据源。@yaswanth添加了导入语句,我使用的是“org.springframework.beans.factory.annotation.Qualifier”注释