Spring JDBC包提供了JdbcTemplate和它的两个兄弟SimpleJdbcTemplate和NamedParameterJdbcTemplate。
NamedParameterJdbcTemplate类是基于JdbcTemplate类,并对它进行了封装从而支持命名参数特性。
NamedParameterJdbcTemplate主要提供以下三类方法:execute方法、query及queryForXXX方法、update及batchUpdate方法。
命名参数设值有两种方式:java.util.Map和SqlParameterSource:
1)Map:使用Map键数据来对于命名参数,而Map值数据用于设值;
2)SqlParameterSource:可以使用SqlParameterSource实现作为来实现为命名参数设值,默认有MapSqlParameterSource和BeanPropertySqlParameterSource实现;MapSqlParameterSource实现非常简单,只是封装了java.util.Map;而BeanPropertySqlParameterSource封装了一个JavaBean对象,通过JavaBean对象属性来决定命名参数的值。
其中有两个比较实用的两个类,分别是BeanPropertySqlParameterSource、BeanPropertyRowMapper。
BeanPropertySqlParameterSource:可以把实例转化成SqlParameterSource
例,new BeanPropertySqlParameterSource(new User);
BeanPropertyRowMapper:可以把返回的每一行转化成对应的对象
例,new BeanPropertyRowMapper<>(CustomSearchVo.class);
项目中的示例:
@Service("repeatContactsService") @Transactional public class RepeatContactsService { private static final Logger LOG = LoggerFactory.getLogger(RepeatContactsService.class); @Resource private NamedParameterJdbcTemplate namedParameterJdbcTemplate; public int getRepeatContactsCountByPhone(String userid, String phone){ String sql= "SELECT count(1) FROM tab_user WHERE userid != :userid AND number = :phone"; Map parmas = ImmutableMap.of("userid",userid,"phone",phone); Integer count = null; try { count = namedParameterJdbcTemplate.queryForObject(sql, parmas, Integer.class); } catch (DataAccessException e) { LOG.error("获取值时抛错:", e); } return count; } public ListgetAllRepeatContacts(String userid) { DateTime before = DateTime.now(); Set phoneSet = new HashSet<>(); String sql = "SELECT contacts_phone FROM tab_contacts WHERE userid=:userid"; Map param = ImmutableMap.of("userid", userid); List phoneList = null; try { phoneList = namedParameterJdbcTemplate.queryForList(sql , param, String.class); } catch (DataAccessException e) { LOG.error("获取用户的通讯录和运营商时抛错:", e); } //生成需要返回的结果 Map params = ImmutableMap.of("phones", phoneSet, "userid", userid); String sql = "SELECT a.name,a.phone,MAX(a.type),b.name userName,b.phone userPhone,b.idcard userIdcard FROM tab_contacts a where call_number in (:phones) AND userid != :userid GROUP BY a.userid,a.phone"; List contactsList = new ArrayList<>(); try { contactsList = namedParameterJdbcTemplate. query(sql, params, new BeanPropertyRowMapper<>(RepeatContactsDetailVo.class)); } catch (DataAccessException e) { LOG.error("获取时抛错:", e); } return contactsList ; } }
推荐看讲NamedParameterJdbcTemplate:
http://www.voidcn.com/blog/victor_cindy1/article/p-6153531.html
讲解JdbcTemplate接口比较好的
https://my.oschina.net/u/218421/blog/38598