BeanPostProcessor
przetworzy wszystkie ziarna w ApplicationContext
i w ten sposób możesz dodać dodatkową konfigurację lub całkowicie ją wymienić, jeśli chcesz.
Możesz utworzyć BeanPostProcessor
które dodałyby właściwości do skonfigurowanego DataSource
. Poniższy przykład zakłada użycie commons-dbcp
1 lub 2, jeśli używasz innego DataSource
odpowiednio zmodyfikować.
public class DataSourceConfiguringBeanPostProcessor implements BeanPostProcessor {
private final Map<String,String> properties = new HashMap<>;
public Object postProcessBeforeInitialization(Object bean, String beanName) throws BeansException {
if (bean instance BasicDataSource ) {
for (Map.Entry<String, String> prop : properties.entrySet()) {
((BasicDataSource) bean).addConnectionProperty(prop.getKey(), prop.getValue());
}
}
return bean;
}
public Object postProcessAfterInitialization(Object bean, String beanName) throws BeansException {
return bean;
}
public void setProperties(Map<String, String> properties) {
this.properties.putAll(properties);
}
}
Teraz możesz dodać to do swojej konfiguracji i doda właściwości do DataSource
fasolki.
@Bean
public BeanPostProcessor dataSourcePostProcessor() {
DataSourceConfiguringBeanPostProcessor processor = new DataSourceConfiguringBeanPostProcessor();
Map<String, String> properties = new HashMap<>();
properties.put("defaultRowPrefetch", "15");
properties.put("defaultBatchValue", "25");
processor.setProperties(properties);
return processor;
}
To powinno wystarczyć do konfiguracji źródła danych.