2

我正在尝试学习 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>

这可能吗 ?

4

1 回答 1

4

可以引用像您的dataSource.

你的班级应该有一个可以持有的成员dataSource

package mypackage;

public class MyBean {

  private DataSource dataSource;

  public void setDataSource(DataSource dataSource) {
    this.dataSource = data.Source;
  }
}

然后你可以将dataSourcebean 注入到这个 bean 中:

<beans>
  <bean id="dataSource" class="org.apache.tomcat.jdbc.pool.DataSource">
    <!-- set properties -->
  </bean>

  <bean id="myBean" class="mypackage.MyBean">
    <property name="dataSource" ref="dataSource"/>
  </bean>
</beans>

而已。

于 2013-06-10T14:21:56.707 回答