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实现汇总的更多相关文章

  1. Spring JdbcTemplate 查询结果集Map反向生成Java实体(转)

    原文地址:Spring JdbcTemplate 查询结果集Map反向生成Java实体 以前写过一篇文章吐槽过Spring JdbcTemplate的queryForList方法(参见:http:// ...

  2. Spring JdbcTemplate 查询出的Map,是如何产生大小写忽略的Key的?(转)

    原文地址:Spring JdbcTemplate 查询出的Map,是如何产生大小写忽略的Key的? 原始讨论组:用Spring JdbcTemplate 查询出的Map,是如何产生大小写忽略的Key的 ...

  3. Spring JdbcTemplate查询实例

    这里有几个例子向您展示如何使用JdbcTemplate的query()方法来查询或从数据库提取数据.整个项目的目录结构如下: 1.查询单行数据 这里有两种方法来查询或从数据库中提取单行记录,并将其转换 ...

  4. [转] spring JdbcTemplate 查询,使用BeanPropertyRowMapper

    [From] http://blog.csdn.net/limenghua9112/article/details/45096437 应用: 使用Spring的JdbcTemplate查询数据库,获取 ...

  5. [转]Spring JdbcTemplate 查询分页

    原文:http://blog.csdn.net/xiaofanku/article/details/4280128 现在进行的项目由于数据库的遗留原因(设计的不堪入目)不能用hibernate.所以用 ...

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

    有句话这样说  欲练神功  挥刀自宫  请亲们先回到第一个  从Spring data 介绍 开始看  搭好环境 跟着步伐一块走 Spring Data 的方法必须严格按照它的规范进行编写,如果写错了 ...

  7. 将前端请求中的数据绑定到Spring MVC响应方法中参数的四种方法

    一.映射URL绑定的占位符到方法参数 1.方法 使用@PathVariable注解 2.代码示例 a.接收请求方法 @RequestMapping(value = "/deleteInfo/ ...

  8. Spring Data Jpa (三)定义查询方法

    本章详细讲解如何利用方法名定义查询方法(Defining Query Methods) (1)定义查询方法的配置方法 由于Spring JPA Repository的实现原理是采用动态代理的机制,所以 ...

  9. Spring JdbcTemplate操作小结

    Spring 提供了JdbcTemplate 来封装数据库jdbc操作细节: 包括: 数据库连接[打开/关闭] ,异常转义 ,SQL执行 ,查询结果的转换 使用模板方式封装 jdbc数据库操作-固定流 ...

随机推荐

  1. springMVC中jackson的使用(包含JsonFormat 时间格式)

    前台使用ajax,后台 springMVC Java下常见的Json类库有Gson.JSON-lib和Jackson等,Jackson相对来说比较高效,在项目中主要使用Jackson进行JSON和Ja ...

  2. spring 配置多个properties

    复制多份,保证有效的配置文件,属性时true就行 <bean class="org.springframework.beans.factory.config.PropertyPlace ...

  3. SnowKiting 2017/1/24

    原文 Let's go fly a kite...in the snow Your snowkiting checklist To snowkite safely,you'll need a litt ...

  4. codevs 2277 爱吃皮蛋的小明(水题日常)

    时间限制: 1 s  空间限制: 32000 KB  题目等级 : 白银 Silver 题目描述 Description 小明特别爱吃蛋,特别是皮蛋.他一次可以吃一个蛋或者两个蛋(整个吞下去),而且他 ...

  5. Android(java)学习笔记142:Android中补间动画(Tween Animation)

    本文主要简单介绍补间动画使用代码实现, 关于使用xml实现补间动画, 可以参看:自定义控件三部曲之动画篇(一)——alpha.scale.translate.rotate.set的xml属性及用法 1 ...

  6. history 路由且带二级目录的Apache配置

    有多个项目目录的时候 由于项目不知一个,所以不得不为每一个项目建一个专有的文件夹,这就导致了在配置nginx的时候会出现二级目录   - step1: 修改 vue.config.js   添加配置 ...

  7. java运行环境jdk的安装和环境变量的配置教程

    jdk的下载与安装 一.官网下载jdk 1.百度搜索jdk,进入官网,如下图所示: 官网下载jdk图1 2.在官网网站中找到合适的版本下载(以最新版本为例),如下图所示: 官网下载jdk图2 官网下载 ...

  8. _IO_FILE

    hctf2017的babyprintf解法是house of orange,深入学习了一下,牵扯出许多知识,这里先进行第一步:_IO_FILE结构 0x00 _IO_FILE glibc-2.2.1\ ...

  9. SpringMVC+Spring+Mybatis整合程序之整合

    因为每个人思路不一样,所以我在这边先分享自己的思路对于mybatis开发持久层(DAO:DataBase Access Object 持久层访问对象)有两种.第一种:传统的开发持久层方式即需要程序员开 ...

  10. sha1、base64、ase加密

    <!DOCTYPE html><html><head><title>sha1.base64.ase加密</title><meta ch ...