Spring JdbcTemplate 查询方法中的RowMapper实现汇总

sping中的RowMapper可以将数据中的每一行数据封装成用户定义的类.

我们在数据库查询中,如果返回的类型是用户自定义的类型(其实我们在数据库查询中大部分返回的都是自定义的类)则需要包装,如果是Java自定义的类型,如:String则不需要.

如果sping与hibernate 相结合了,基本上是用不到,大多数都是在spring单独使用时用到.

可以通过建立内部类实现RowMapper接口,RowMapper中有一个mapRow方法,所以实现RowMapper接口一定要实现mapRow方法,而对自定义类的包装就在mapRow方法中实现.

这里只是一个简单的例子:

public class TestDao {
private JdbcTemplate jt;
public void setJt(JdbcTemplate jt) {
   this.jt = jt;
}
public List<TNpc> getAll(){
    String sql = "select * from t_npc";
   //使用
   List list = jt.query(sql, new NpcRowMapper());
   return list;
}
/**
* 定义内部类实现RowMapper接口
*/
public class NpcRowMapper implements RowMapper{
      //实现mapRow方法
     public Object mapRow(ResultSet rs, int num) throws SQLException {
        //对类进行封装
      TNpc npc = new TNpc();
      npc.setId(rs.getLong("id"));
      npc.setName(rs.getString("name"));
      return npc;
   }  
   }
}

Java代码  

  1. 实现一、在内部建立内联类实现RowMapper接口
  2. package hysteria.contact.dao.impl;
  3. import java.sql.ResultSet;
  4. import java.sql.SQLException;
  5. import java.sql.Types;
  6. import java.util.List;
  7. import org.springframework.jdbc.core.JdbcTemplate;
  8. import org.springframework.jdbc.core.RowMapper;
  9. import hysteria.contact.dao.ItemDAO;
  10. import hysteria.contact.domain.Item;
  11. public class ItemDAOImpl implements ItemDAO {
  12. private JdbcTemplate jdbcTemplate;
  13. public void setJdbcTemplate(JdbcTemplate jdbcTemplate) {
  14. this.jdbcTemplate = jdbcTemplate;
  15. }
  16. public Item insert(Item item) {
  17. String sql = "INSERT INTO items(user_id,name,phone,email) VALUES(?,?,?,?)";
  18. Object[] params = new Object[]{item.getUserId(),item.getName(),item.getPhone(),item.getEmail()};
  19. int[] types = new int[]{Types.INTEGER,Types.VARCHAR,Types.CHAR,Types.VARCHAR};
  20. jdbcTemplate.update(sql,params,types);
  21. return item;
  22. }
  23. public Item update(Item item) {
  24. String sql = "UPDATE items SET name = ?, phone = ?, email = ? WHERE id = ?";
  25. Object[] params = new Object[] {item.getName(),item.getPhone(),item.getEmail(),item.getId()};
  26. int[] types = new int[] {Types.VARCHAR,Types.CHAR,Types.VARCHAR,Types.VARCHAR,Types.INTEGER};
  27. jdbcTemplate.update(sql,params,types);
  28. return item;
  29. }
  30. public void delete(Item item) {
  31. String sql = "DELETE FROM items WHERE id = ?";
  32. Object[] params = new Object[] {item.getId()};
  33. int[] types = new int[]{Types.INTEGER};
  34. jdbcTemplate.update(sql,params,types);
  35. }
  36. public Item findById(int id) {
  37. String sql = "SELECT * FROM items WHERE id = ?";
  38. Object[] params = new Object[] {id};
  39. int[] types = new int[] {Types.INTEGER};
  40. List items = jdbcTemplate.query(sql,params,types,new ItemMapper());
  41. if(items.isEmpty()){
  42. return null;
  43. }
  44. return (Item)items.get(0);
  45. }
  46. public List<Item> findAll() {
  47. String sql = "SELECT * FROM items";
  48. return jdbcTemplate.query(sql,new ItemMapper());
  49. }
  50. public List<Item> findAllByUser(int user_id) {
  51. String sql = "SELECT * FROM items WHERE user_id = ?";
  52. Object[] params = new Object[]{user_id};
  53. int[] types = new int[]{Types.INTEGER};
  54. List items = jdbcTemplate.query(sql,params,types,new ItemMapper());
  55. return items;
  56. }
  57. protected class ItemMapper implements RowMapper {
  58. public Object mapRow(ResultSet rs, int rowNum) throws SQLException {
  59. Item item = new Item();
  60. item.setId(rs.getInt("id"));
  61. item.setUserId(rs.getInt("user_id"));
  62. item.setName(rs.getString("name"));
  63. item.setPhone(rs.getString("phone"));
  64. item.setEmail(rs.getString("email"));
  65. return item;
  66. }
  67. }
  68. }

Spring JdbcTemplate 查询方法中的RowMapper实现汇总

时间: 2024-10-10 09:18:00

Spring JdbcTemplate 查询方法中的RowMapper实现汇总的相关文章

Spring JdbcTemplate 查询分页

1.大家都有的page类 [java] view plaincopy public class CurrentPage<E> { private int pageNumber; private int pagesAvailable; private List<E> pageItems = new ArrayList<E>(); public void setPageNumber(int pageNumber) { this.pageNumber = pageNumber

JdbcTemplate查询数据中两种处理结果集方法的简单比较

public List<Cat> listCats(){ //多条数据查询 String sql = "select id, name, description, mother_id, createDate from tbl_cat"; /*//方法1.使用RowMapper<Cat>处理结果集 return jdbcTemplate.query(sql, new RowMapper<Cat>(){ @Override public Cat mapR

Spring JdbcTemplate查询实例

这里有几个例子向您展示如何使用JdbcTemplate的query()方法来查询或从数据库提取数据.整个项目的目录结构如下: 1.查询单行数据 这里有两种方法来查询或从数据库中提取单行记录,并将其转换成一个模型类. 1.1 自定义RowMapper 在一般情况下,它总是建议实现 RowMapper 接口来创建自定义的RowMapper,以满足您的需求. package com.yiibai.customer.model; import java.sql.ResultSet; import jav

spring JdbcTemplate 查询,使用BeanPropertyRowMapper

应用: 使用Spring的JdbcTemplate查询数据库,获取List结果列表,数据库表字段和实体类自动对应,可以使用BeanPropertyRowMapper. 注意: 自动绑定,需要列名称和Java实体类名字一致,如:属性名 "userName" 可以匹配数据库中的列字段 "USERNAME" 或 "user_name".这样,我们就不需要一个个手动绑定了,大大提高了开发效率. org.springframework.jdbc.core.

Spring Data 查询方法的规则定义(五)

有句话这样说  欲练神功  挥刀自宫  请亲们先回到第一个  从Spring data 介绍 开始看  搭好环境 跟着步伐一块走 Spring Data 的方法必须严格按照它的规范进行编写,如果写错了就不行 下面是网上找的一张图:仔细看 咱们先拿几个方法来做个示例 在这之前  先往数据表插入一些数据 insert into employee(name,age) values('wangwu',12); ..... 你们自己插写数据  先贴下我的数据 继续 基于原先的代码进行修改  Employe

spring jdbcTemplate查询使用

1.查询一行数据并返回int型结果 jdbcTemplate.queryForInt("select count(*) from test"); 2. 查询一行数据并将该行数据转换为Map返回 jdbcTemplate.queryForMap("select * from test where name='name5'"); 3.查询一行任何类型的数据,最后一个参数指定返回结果类型 jdbcTemplate.queryForObject("select c

Spring JdbcTemplate操作小结

Spring 提供了JdbcTemplate 来封装数据库jdbc操作细节: 包括: 数据库连接[打开/关闭] ,异常转义 ,SQL执行 ,查询结果的转换 使用模板方式封装 jdbc数据库操作-固定流程的动作,提供丰富callback回调接口功能,方便用户自定义加工细节,更好模块化jdbc操作,简化传统的JDBC操作的复杂和繁琐过程. 1) 使用JdbcTemplate 更新(insert /update /delete) Java代码   int k = jdbcTemplate.update

Spring JdbcTemplate的queryForList(String sql , Class&lt;T&gt; elementType)易错使用--转载

原文地址: http://blog.csdn.net/will_awoke/article/details/12617383 一直用ORM,今天用JdbcTemplate再次抑郁了一次. 首先看下这个方法: 乍一看,我想传个泛型T(实际代码执行中,这个T可以是我自定义的一个Bean),然后就能返回个List<T>,也即泛型的集合(纯ORM思想啊!殊不知又挖了个大坑~) 于是乎,出现下面代码: [java] view plaincopy List<Student> list = jd

Dynamic CRM 2015学习笔记(3)oData 查询方法及GUID值比较

本文将比较二种查询字符串在同一个oData查询方法中的不同,另外,还将介绍如何比较不同方法返回的GUID的值. 用同一个oData查询方法,如果传入查询的字符串不一样,返回结果的格式竟然完全不一样. 1. oData查询方法: //OData查询 ODataRetrieve: function (oDataString) { var retrieveReq = new XMLHttpRequest(); retrieveReq.open("GET", encodeURI(Xrm.Pag