ja z powodzeniem udało się wdrożyć dynamiczną zmianę połączeń z bazą danych, wykonując http://blog.springsource.com/2007/01/23/dynamic-datasource-routing/ artykuł.dynamicznie tworzyć fasoli wiosenne i zmieniać właściwości istniejących ziaren
Ale teraz jest problem, mam listę adresów URL bazy danych w pliku konfiguracyjnym, które są zarządzane przez starszych aplikacji.
Czy istnieje sposób na tworzenie fasoli w tym kontekście Spring z listy wartości (np. Year2011DataSource, Year2012DataSource, ...) i zapełnić mapę fasoli źródła danych tymi fasolami, które właśnie zostały utworzone?
<!-- Property file located in the legacy application's folder -->
<context:property-placeholder location="file:///D:/config.properties" />
<!-- Shared data source properties are read from the config.properties file -->
<bean id="parentDataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource" abstract="true">
<property name="driverClassName" value="${db.driver}" />
<property name="username" value="${db.user}" />
<property name="password" value="${db.password}" />
</bean>
<!-- Database urls by year -->
<bean id="Year2012DataSource" parent="parentDataSource">
<property name="url" value="jdbc:sqlserver://localhost;databaseName=DbName_v570_2012" />
</bean>
<bean id="Year2011DataSource" parent="parentDataSource">
<property name="url" value="jdbc:sqlserver://localhost;databaseName=DbName_v570_2011" />
</bean>
<bean id="Year2010DataSource" parent="parentDataSource">
<property name="url" value="jdbc:sqlserver://localhost;databaseName=DbName_v570_2010" />
</bean>
<!-- ... and so on, these should instead be populated dynamically ... -->
<!-- DbConnectionRoutingDataSource extends AbstractRoutingDataSource -->
<bean id="dataSource" class="someProject.DbConnectionRoutingDataSource">
<property name="targetDataSources">
<map key-type="int">
<entry key="2011" value-ref="Year2011DataSource" />
<entry key="2010" value-ref="Year2010DataSource" />
<!-- ... and so on, these also should instead be populated dynamically ... -->
</map>
</property>
<property name="defaultTargetDataSource" ref="Year2012DataSource" />
</bean>
Dodany ostateczna wersja kodu. Dzięki za pomoc ludziom. – Vedran