Я использую Spring 3.0 и JDBC. В настоящее время я экспериментирую с Spring для настольных приложений.Каждый раз, когда класс должен использовать источник данных, объявленный в моем spring_bean_file.xml, мне нужно было бы объявить каждый из них в файле xml и снова инициализировать каждый из них в моем классе.
Ниже приведен мой файл xml
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">
<property name="driverClassName" value="oracle.jdbc.driver.OracleDriver"/>
<property name="url" value="#{T(java.lang.System).getenv(DB_URL')}"/>
<property name="username" value="#{T(java.lang.System).getenv('DB_USER')}"/>
<property name="password" value="#{T(java.lang.System).getenv('DB_PASS')}"/>
</bean>
<bean id="classA" class="com.example.ClassA">
<property name="dataSource" ref="dataSource"/>
</bean>
<bean id="classB" class="com.example.ClassB">
<property name="dataSource" ref="dataSource"/>
</bean>
Это мой код Java:
public static void main(String[] args) {
ApplicationContext context = new ClassPathXmlApplicationContext("spring_bean_file.xml");
ClassA classA = (ClassA) context.getBean("classA");
ClassB classB = (ClassB) context.getBean("classB");
try {
rrRpi.generateRrRpi();
rrSpi.generateRrSpi();
} catch (SQLException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
//close the context
((ClassPathXmlApplicationContext) context).close();
}
Я хотел бы знать, есть ли более эффективный способ сделать это.Что является лучшим подходом, поэтому мне не нужно добавлять бин для каждого класса, который будет использовать DataSoruce.Заранее спасибо, ребята.