private String validationQuery;
@Value(“${testWhileIdle}”)
private boolean testWhileIdle;
@Value(“${testOnBorrow}”)
private boolean testOnBorrow;
@Value(“${testOnReturn}”)
private boolean testOnReturn;
@Value(“${maxPoolPreparedStatementPerConnectionSize}”)
private int maxPoolPreparedStatementPerConnectionSize;
@Value(“${removeAbandoned}”)
private boolean removeAbandoned;
@Value(“${removeAbandonedTimeout}”)
private int removeAbandonedTimeout;
@Value(“${timeBetweenEvictionRunsMillis}”)
private int timeBetweenEvictionRunsMillis;
@Value(“${minEvictableIdleTimeMillis}”)
private int minEvictableIdleTimeMillis;
@Bean(initMethod=“init”,destroyMethod=“close”)
public DruidDataSource dataSource(){
DruidDataSource dataSource=new DruidDataSource();
try {
dataSource.setUrl(url);
dataSource.setDriverClassName(driverClassName);
dataSource.setUsername(username);
dataSource.setPassword(password);
dataSource.setFilters(filters);
dataSource.setInitialSize(initialSize);
dataSource.setMaxActive(maxActive);
dataSource.setMinIdle(minIdle);
dataSource.setMaxWait(maxWait);
dataSource.setValidationQuery(validationQuery);
dataSource.setTestWhileIdle(testWhileIdle);
dataSource.setTestOnBorrow(testOnBorrow);
dataSource.setTestOnReturn(testOnReturn);
dataSource.setMaxPoolPreparedStatementPerConnectionSize(maxPoolPreparedStatementPerConnectionSize);
dataSource.setRemoveAbandoned(removeAbandoned);
dataSource.setRemoveAbandonedTimeout(removeAbandonedTimeout);
dataSource.setTimeBetweenEvictionRunsMillis(timeBetweenEvictionRunsMillis);
dataSource.setMinEvictableIdleTimeMillis(minEvictableIdleTimeMillis);
System.out.println(“连接池启动成功”);
} catch (SQLException e) {
e.printStackTrace();
}
return dataSource;
}
}
5、事务的使用
@Service
public class UserServiceImpl implements UserService {
@Autowired
private JdbcTemplate jdbcTemplate;
@Override
@Transactional
public void insertUser(User user) {
String sql = “insert into user(id, name) values(?,?)”;
jdbcTemplate.update(sql, user.getId(), user.getName());
//int num = 1/0; //放开测试事务。预期结果为添加失败,库中无数据。测试结果与预期一致
}
}

本文详细介绍了如何在Spring Boot中配置和使用JdbcTemplate,包括执行DDL语句、增删改查操作及事务控制。示例展示了如何在UserService中使用@Transactional进行事务管理,并提供了DAO层代码实现。同时,还详细讲解了JdbcTemplate的各种查询方法,如queryForInt、queryForLong、queryForObject、queryForMap和queryForList,以及通过RowMapper和BeanPropertyRowMapper返回自定义对象的方法。
1万+

被折叠的 条评论
为什么被折叠?



