sql >> Database >  >> NoSQL >> MongoDB

Beannamen van Spring Data-repository's aanpassen voor gebruik met meerdere gegevensbronnen

Maak uw repository-interface met @NoRepositoryBean , we zullen het zelf aansluiten:

@NoRepositoryBean
public interface ModelMongoRepository extends MongoRepository<Model, String> {
}      

Dan, in een @Configuration class, maak dan de 2 repository-beans aan met behulp van MongoRepositoryFactoryBean . Beide repositories retourneren dezelfde Spring Data Repository-interface, maar we zullen ze verschillende MongoOperations toewijzen (dwz:databasedetails):

@Configuration
@EnableMongoRepositories
public class MongoConfiguration {

    @Bean
    @Qualifier("one")
    public ModelMongoRepository modelMongoRepositoryOne() throws DataAccessException, Exception {
        MongoRepositoryFactoryBean<ModelMongoRepository, Model, String> myFactory = new MongoRepositoryFactoryBean<ModelMongoRepository, Model, String>();
        myFactory.setRepositoryInterface(ModelMongoRepository.class);
        myFactory.setMongoOperations(createMongoOperations("hostname1", 21979, "dbName1", "username1", "password1"));
        myFactory.afterPropertiesSet();
        return myFactory.getObject();
    }

    @Bean
    @Qualifier("two")
    public ModelMongoRepository modelMongoRepositoryTwo() throws DataAccessException, Exception {
        MongoRepositoryFactoryBean<ModelMongoRepository, Model, String> myFactory = new MongoRepositoryFactoryBean<ModelMongoRepository, Model, String>();
        myFactory.setRepositoryInterface(ModelMongoRepository.class);
        myFactory.setMongoOperations(createMongoOperations("hostname2", 21990, "dbName2", "username2", "password2"));
        myFactory.afterPropertiesSet();
        return myFactory.getObject();
    }

    private MongoOperations createMongoOperations(String hostname, int port, String dbName, String user, String pwd) throws DataAccessException, Exception {
        MongoCredential mongoCredentials = MongoCredential.createScramSha1Credential(user, dbName, pwd.toCharArray());
        MongoClient mongoClient = new MongoClient(new ServerAddress(hostname, port), Arrays.asList(mongoCredentials));
        Mongo mongo = new SimpleMongoDbFactory(mongoClient, dbName).getDb().getMongo();
        return new MongoTemplate(mongo, dbName);
    }
    //or this one if you have a connection string
    private MongoOperations createMongoOperations(String dbConnection) throws DataAccessException, Exception {
        MongoClientURI mongoClientURI = new MongoClientURI(dbConnection);
        MongoClient mongoClient = new MongoClient(mongoClientURI);
        Mongo mongo = new SimpleMongoDbFactory(mongoClient, mongoClientURI.getDatabase()).getDb().getMongo();
        return new MongoTemplate(mongo, mongoClientURI.getDatabase());
    }
}

Je hebt nu 2 bonen met verschillende @Qualifier namen, elk geconfigureerd voor verschillende databases en met hetzelfde model.

Je kunt ze injecteren met @Qualifier :

@Autowired
@Qualifier("one")
private ModelMongoRepository mongoRepositoryOne;

@Autowired
@Qualifier("two")
private ModelMongoRepository mongoRepositoryTwo;

Voor de eenvoud heb ik de waarden in de configuratieklasse hard gecodeerd, maar je kunt ze injecteren vanuit eigenschappen in application.properties/yml.

Dit is de wijziging als u een aangepaste implementatie wilt maken zonder de voordelen van opslagplaatsen voor springgegevensinterfaces te verliezen. de specificaties zeggen dit:

Maak een nieuwe interface, die technisch niets te maken heeft met lentegegevens, goede oude interface:

public interface CustomMethodsRepository {
    public void getById(Model model){
}

Laat uw repository-interface deze nieuwe interface uitbreiden:

@NoRepositoryBean
public interface ModelMongoRepository extends MongoRepository<Model, String>, CustomMethodsRepository {
} 

Maak vervolgens uw implementatieklasse, die alleen implementeert uw niet-spring-data-interface:

public class ModelMongoRepositoryImpl  implements CustomModelMongoRepository {
    private MongoOperations mongoOperations;

    public ModelMongoRepositoryImpl(MongoOperations mongoOperations) {
        this.mongoOperations = mongoOperations;
    }
    public void getById(Model model){
        System.out.println("test");
    }
}

Wijzig de Java-configuratie om myFactory.setCustomImplementation(new ModelMongoRepositoryImpl()); toe te voegen :

@Bean
@Qualifier("one")
public ModelMongoRepository modelMongoRepositoryOne() throws DataAccessException, Exception {
    MongoRepositoryFactoryBean<ModelMongoRepository, Model, String> myFactory = new MongoRepositoryFactoryBean<ModelMongoRepository, Model, String>();
    MongoOperations mongoOperations = createMongoOperations("hostname1", 21979, "dbName1", "usdername1", "password1");
    myFactory.setCustomImplementation(new ModelMongoRepositoryImpl(mongoOperations));
    myFactory.setRepositoryInterface(ModelMongoRepository.class);
    myFactory.setMongoOperations(mongoOperations);

    myFactory.afterPropertiesSet();
    return myFactory.getObject();
}

Als u de repository niet handmatig via Java-configuratie zou bedraden, MOET deze implementatie ModelMongoRepositoryImpl heten. om overeen te komen met de interface ModelMongoRepository +"Impl" . En het zou in de lente automatisch worden afgehandeld.



  1. mongodb tel tellen zonder te herhalen vinden

  2. Realtime chatten met Modulus en Node.js

  3. Wat is de maximale waarde die u in redis kunt opslaan?

  4. Mongodb Healthcheck stap voor stap