使用JdbcTemplate查询方法的返回值

使用JdbcTemplate进行查询时,可以使用queryForXXX()等方法

1   jdbcTemplate.queryForInt() 和 jdbcTemplate.queryForLong()

例如下面使用queryForInt()方法传回user表中的记录数:

jdbcTemplate.queryForInt("SELECT COUNT(*) FROM user");


2 jdbcTemplate.queryForObject()

 

本质上和queryForInt(),相同。返回都是单行单列一个数据。例如下例传回一个String对象:

String name = (String) jdbcTemplate.queryForObject(
"SELECT name FROM USER WHERE id = ?",
new Object[] {id},
java.lang.String.class);

 

 

3 jdbcTemplate.queryForList(???)

 

 

返回 a List of Maps, using column name as key. 每一个map代表一条记录 例如:
List rows = jdbcTemplate.queryForList("SELECT * FROM user");

 

 

for(int i=0;i<rows.size();i++){

Map userMap=rows.get(i);

 

System.out.println(userMap.get("id"));
System.out.println(userMap.get("name"));
System.out.println(userMap.get("age"));

}


4 jdbcTemplate.queryForMap(???)

queryForList(), 差不多,只是预期查询一行数据。返回 a Map, using column name as key.

The query is expected to be a single row query

 

5 jdbcTemplate.queryForRowSet(???)

 

返回RowSet, representing disconnected java.sql.ResultSet

 

JDBCTemplate的使用很简单,只要在ApplicationContext文件里定义一个jdbcTemplate节点,POJO获得注入后可以直接执行操作,不需要继承什么基类。

xml 代码
  1. <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">          
  2.       <property name="dataSource" ref="dataSource"/>       
  3. </bean>  

 

java 代码
  1. SqlRowSet rs = jdbcTemplate.queryForRowSet(sql, params);  

 

Tips1: jdbcTemplate有很多的ORM化回调操作将返回结果转为对象列表,但很多时候还是需要返回ResultSet,Spring有提供一个类似ResultSet的,实现JDBC3.0 RowSet接口的 Spring SqlRowSet。

Tips2:.注意jdbcTemplate尽量只执行查询操作,莫要进行更新,否则会破坏Hibernate的二级缓存体系。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值