使用JdbcTemplate获取多表查询结果集并返回json数组

Spring中,JdbcTemplate的query方法的参数中实现RowMapper接口,可以将查询结果的每行映射为数据库表对应的EntityBean,并最终返回List<EntityBean>,这个属于基本运用,但实际应用往往是多表查询返回的结果集并非可以直接映射为表的实体类;另,jsp页面使用ajax返回结果为json字符串处理起来相对方便;下面记录一下sping JdbcTemplate多表查询结果处理为json字符串并在页面展现。

 

1,JdbcTemplate DAO

两表连接查询,获取结果集为List<Map>,方便处理为json数组

@Repository
public class DAOJdbcTemplate {
	private static Logger log =  Logger.getLogger(DAOJdbcTemplate.class.getName());
	
	private JdbcTemplate jdbctemplate;
	
	@Autowired
	public void setDataSource(DataSource dbcp2datasource){
		this.jdbctemplate = new JdbcTemplate(dbcp2datasource);
	} 
		
	public List getInfoList(String pubday, String title){//
		StringBuffer sql = new StringBuffer();
		List lst = null;

		sql.append("select t.title as title
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
获取`application-druid.yml`中的连接对象,需要使用Druid数据源。Druid是阿里巴巴开发的JDBC连接池,具有监控、防御SQL注入攻击和并发控制等特性。 以下是获取`application-druid.yml`的连接对象的示例代码: ```java import com.alibaba.druid.pool.DruidDataSource; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.context.properties.EnableConfigurationProperties; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import javax.sql.DataSource; @Configuration @EnableConfigurationProperties(DatabaseProperties.class) public class DataSourceConfig { @Autowired private DatabaseProperties properties; @Bean public DataSource dataSource() { DruidDataSource dataSource = new DruidDataSource(); dataSource.setUrl(properties.getUrl()); dataSource.setUsername(properties.getUsername()); dataSource.setPassword(properties.getPassword()); // 设置其他属性,例如连接池大小、连接超时等 return dataSource; } } ``` 在上面的示例中,`@EnableConfigurationProperties`注解用于启用`DatabaseProperties`类,`@Autowired`注解则将`DatabaseProperties`类注入到`DataSourceConfig`类中。`dataSource()`方法用于创建一个`DruidDataSource`对象,并设置连接信息,最后将其返回。可以在方法中设置其他的属性,例如最大连接数、最小连接数、连接超时时间等。需要注意的是,`dataSource()`方法需要使用`@Bean`注解,以便Spring容器可以自动注入数据源。 在使用连接对象时,只需将`DataSource`对象注入到需要连接数据库的代码中即可。例如: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.stereotype.Component; @Component public class MyDao { private final JdbcTemplate jdbcTemplate; @Autowired public MyDao(DataSource dataSource) { this.jdbcTemplate = new JdbcTemplate(dataSource); } // 使用jdbcTemplate执行SQL语句 } ``` 在上面的示例中,`MyDao`类中包含一个`jdbcTemplate`对象,它通过构造函数注入了`DataSource`对象,以便可以使用`jdbcTemplate`对象执行SQL语句。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值