使用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"));
}
4jdbcTemplate.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