我正在尝试了解基于Spring Java的配置。通常我可能有一个包含以下内容的XML配置:
<context:property-placeholder location="jdbc.properties"/>
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"
p:driverClassName="${jdbc.driverClassName}"
p:ur="${jdbc.url}"
p:username="${jdbc.username}"
p:password="${jdbc.password}"/>
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate"
p:dataSource-ref="dataSource" />
我努力生成等效但使用基于Spring Java的配置已经停滞不前。我不确定在尝试将我的dataSource注入jdbcTemplate时该怎么做:
@PropertySource("classpath:jdbc.properties")
@Configuration
public class Config {
@Bean
public static PropertySourcesPlaceholderConfigurer propertySourcesPlaceholderConfigurer() {
return new PropertySourcesPlaceholderConfigurer();
}
@Bean(name = "dataSource")
public DataSource dataSource(
@Value("${jdbc.driverClassName}") final String driverClassName,
@Value("${jdbc.url}") final String url,
@Value("${jdbc.username}") final String username,
@Value("${jdbc.password}") final String password) {
BasicDataSource datasource = new BasicDataSource();
datasource.setDriverClassName(driverClassName);
datasource.setUrl(url);
datasource.setUsername(username);
datasource.setPassword(password);
return datasource;
}
@Bean(name = "jdbcTemplate")
public JdbcTemplate jdbcTemplate() {
return new JdbcTemplate(
/* Property 'dataSource' is required and needs to be referenced
* What goes here?
*/
);
}
}
我的猜测是没有直接的等价物,我可能需要以微妙的方式处理事情?
答案 0 :(得分:5)
由于JdbcTemplate包含JdbcTemplate(DataSource dataSource)
构造函数。
你可以试试这种方式
@PropertySource("classpath:jdbc.properties")
@Configuration
public class Config {
@Autowired
private Environment env;
@Bean
public static PropertySourcesPlaceholderConfigurer propertySourcesPlaceholderConfigurer() {
return new PropertySourcesPlaceholderConfigurer();
}
@Bean(name = "dataSource")
public DataSource dataSource() {
BasicDataSource datasource = new BasicDataSource();
datasource.setDriverClassName(env.getProperty("jdbc.driverClassName"));
// Similarly other values
// datasource.setUrl(url);
// datasource.setUsername(username);
// datasource.setPassword(password);
return datasource;
}
@Bean(name = "jdbcTemplate")
public JdbcTemplate jdbcTemplate() {
return new JdbcTemplate(dataSource());
}
}
答案 1 :(得分:1)
您无需在配置中创建jdbcTemplate
。您可以在DAO类中创建它。
在DAO课程中:
private JdbcTemplate jdbcTemplate;
@Autowired
public void setDataSource(final DataSource dataSource) {
jdbcTemplate = new JdbcTemplate(dataSource);
}