我正在尝试学习 spring 框架和 bean 配置,到目前为止它看起来真的很酷。
我即将创建一个通用类来包含我所有的 Mysql 函数,并且它需要包含 DataSource。我的问题是:是否可以在 bean 配置中设置数据源?
如果没有,那么我需要将类设置为单例,创建一个 init 函数并在 init 函数中执行以下操作:
ApplicationContext context = new ClassPathXmlApplicationContext("beans.xml");
DataSource ds = (DataSource) context.getBean("dataSource");
问题是,我可以直接在 bean 中“注入”(如果这是正确的术语,不要这样做),而不是这样做?
这是我的 bean 配置。
<bean id="dataSource" class="org.apache.tomcat.jdbc.pool.DataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver" />
<property name="url" value="jdbc:mysql://localhost:3306/foo"/>
<property name="username" value="root"></property>
<property name="password" value="password"></property>
<property name="validationQuery" value="SELECT 1" />
<property name="testOnBorrow" value="true" />
<property name="testWhileIdle" value="true" />
<property name="initialSize" value="5" />
</bean>
<bean id="bar" class="foo.bar">
<property name="dataSource" value="<HERE_SETTING_THE_DATA_SOURCE_ABOVE>" />
</bean>
这可能吗 ?