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. VS 2013如何编译ASM文件

    1.  左键点击解决方案下面的工程 2.  点击上面菜单中的项目,此时有个生成自定义属性 3.  勾选上masm,此时就有Microsoft Macro Assembler了 https://stac ...

  2. spring 中bean学习笔记

    spring 中bean 一.bean的定义和应用 1. bean 形象上类似于getXX()和setXX()的一种. 2. 由于java是面向对象的,类的方法和属性在使用中需要实例化. 3. 规律: ...

  3. 双击窗体是模拟键盘上的Tab键

    实现效果: 知识运用: SendKeys类的Send方法 //向活动应用程序发送击键 public static void Send (string keys) 实现代码: private void ...

  4. 【动态规划】poj2353Ministry

    拓扑序……好些玄妙 Description Mr. F. wants to get a document be signed by a minister. A minister signs a doc ...

  5. 【树形背包】bzoj4033: [HAOI2015]树上染色

    仔细思考后会发现和51nod1677 treecnt有异曲同工之妙 Description 有一棵点数为N的树,树边有边权.给你一个在0~N之内的正整数K,你要在这棵树中选择K个点,将其染成黑色,并 ...

  6. 【Java_多线程并发编程】基础篇——线程状态扭转函数

    1. wait() sleep() yield() join()用法与区别 本文提到的当前线程是指:当前时刻,获得CPU资源正在执行的线程. 1.1 wait()方法 wait()方法定义在Objec ...

  7. MySQL中常见的锁

    一.按读写方式分类 1.读锁又称共享锁,读锁是共享的,读锁之间是互不阻塞. 2.写锁又称排他锁,写锁是排他的,写锁会阻塞其他读锁和写锁 二.按锁的粒度分类 1.表锁是MySQL中最基本的锁策略,该锁的 ...

  8. 蓝牙学习(5) -- sockets

    Frames 由下图可以看出 - SDU由多个I-frames中的Information Payload组成 - 一个I-frames又拆分成多个HCI data payload socket buf ...

  9. 【css】修改placeholder 默认颜色

    html5为input添加了原生的占位符属性placeholder,高级浏览器都支持这个属性,例如: <input type="text" placeholder=" ...

  10. 【css】清楚浏览器端缓存

    /css/common.css?version=1.0.7   在css链接后面加个参数版本号控制,刷新浏览器缓存