`
wusuoya
  • 浏览: 640399 次
  • 性别: Icon_minigender_2
  • 来自: 成都
社区版块
存档分类
最新评论

Spring--JdbcTemplate详解-2

    博客分类:
  • SSH
 
阅读更多

1、由于之前JdbcTemplate的程序需要编写一堆的RowMapper的映射文件,显得有些臃肿,最好是根据pojo类和字段的名称进行自动的对应, 所以SimpleJdbcTemplate支持使用Pojo中的属性进行自动赋值, 语法为':'开头。

Java代码  收藏代码
  1. public   class  UserDaoSpringImpl  implements  UserDao {  
  2.    private  SimpleJdbcTemplate simpleJdbcTemplate =  new  SimpleJdbcTemplate(  
  3.        JdbcUtils.getDataSource());  
  4.    
  5.   public   void  addUser(User user) {  
  6.      String sql = "insert into user (name, money, birthday) values (:name, :money, :birthday)" ;  
  7.      SqlParameterSource param = new  BeanPropertySqlParameterSource(user);  
  8.      KeyHolder keyHolder = new  GeneratedKeyHolder();  
  9.      this .simpleJdbcTemplate.getNamedParameterJdbcOperations().update(sql,  
  10.          param, keyHolder);  
  11.      user.setId(keyHolder.getKey().intValue());  
  12.    }  
  13.    
  14.   public   void  delete(User user) {  
  15.      String sql = "delete from user where id=?" ;  
  16.      this .simpleJdbcTemplate.update(sql, user.getId());  
  17.    }  
  18.    
  19.   public  User findUser(String loginName, String password) {  
  20.      String sql = "select id, name, money, birthday    from user where name=?" ;  
  21.      return   this .simpleJdbcTemplate.queryForObject(sql,  
  22.          ParameterizedBeanPropertyRowMapper.newInstance(User.class ),  
  23.          loginName);  
  24.    }  
  25.    
  26.   public  User getUser( int  userId) {  
  27.      String sql = "select id, name, money, birthday    from user where id=?" ;  
  28.      return   this .simpleJdbcTemplate.queryForObject(sql,  
  29.          ParameterizedBeanPropertyRowMapper.newInstance(User.class ),  
  30.          userId);  
  31.    }  
  32.    
  33.   public   void  update(User user) {  
  34.      String sql = "update user set name=?, birthday=?, money=? where id=? " ;  
  35.      this .simpleJdbcTemplate.update(sql, user.getName(), user.getBirthday(),  
  36.          user.getMoney(), user.getId());  
  37.    
  38.     sql = "update user set name=:name, birthday=:birthday, money=:money where id=:id " ;  
  39.      this .simpleJdbcTemplate.update(sql,  new  BeanPropertySqlParameterSource(  
  40.          user));  
  41.    }  
  42.    
  43. }  


其中使用的JdbcUtils获取数据源的代码如下:

Java代码  收藏代码
  1. public   final   class  JdbcUtils {  
  2.    private   static  String url =  "jdbc:mysql://localhost:3306/jdbc" ;  
  3.    private   static  String user =  "root" ;  
  4.    private   static  String password =  "" ;  
  5.    private   static  DataSource myDataSource =  null ;  
  6.    
  7.   private  JdbcUtils() {  
  8.    }  
  9.    
  10.   static  {  
  11.      try  {  
  12.        Class.forName("com.mysql.jdbc.Driver" );  
  13.        // myDataSource = new MyDataSource2();   
  14.        Properties prop = new  Properties();  
  15.        // prop.setProperty("driverClassName", "com.mysql.jdbc.Driver");   
  16.        // prop.setProperty("user", "user");   
  17.    
  18.       InputStream is = JdbcUtils.class .getClassLoader()  
  19.            .getResourceAsStream("dbcpconfig.properties" );  
  20.        prop.load(is);  
  21.        myDataSource = BasicDataSourceFactory.createDataSource(prop);  
  22.      } catch  (Exception e) {  
  23.        throw   new  ExceptionInInitializerError(e);  
  24.      }  
  25.    }  
  26.    
  27.   public   static  DataSource getDataSource() {  
  28.      return  myDataSource;  
  29.    }  
  30.    
  31.   public   static  Connection getConnection()  throws  SQLException {  
  32.      // return DriverManager.getConnection(url, user, password);   
  33.      return  myDataSource.getConnection();  
  34.    }  
  35.    
  36.   public   static   void  free(ResultSet rs, Statement st, Connection conn) {  
  37.      try  {  
  38.        if  (rs !=  null )  
  39.          rs.close();  
  40.      } catch  (SQLException e) {  
  41.        e.printStackTrace();  
  42.      } finally  {  
  43.        try  {  
  44.          if  (st !=  null )  
  45.            st.close();  
  46.        } catch  (SQLException e) {  
  47.          e.printStackTrace();  
  48.        } finally  {  
  49.          if  (conn !=  null )  
  50.            try  {  
  51.              conn.close();  
  52.              // myDataSource.free(conn);   
  53.            } catch  (Exception e) {  
  54.              e.printStackTrace();  
  55.            }  
  56.        }  
  57.      }  
  58.    }  
  59.  }  



2、 完成相同映射的类还包括:NamedParameterJdbcTemplate, 它将之前的占位符‘?’进行了取名,方便程序的阅读。 不过这样的SQL不能再数据库中直接执行,需要有Spring进行转换。

Java代码  收藏代码
  1. public   class  NamedJdbcTemplate {  
  2.    static  NamedParameterJdbcTemplate named =  new  NamedParameterJdbcTemplate(  
  3.        JdbcUtils.getDataSource());  
  4.    
  5.   /**  
  6.      * @param args  
  7.      */   
  8.    public   static   void  main(String[] args) {  
  9.      User user = new  User();  
  10.      user.setMoney(10 );  
  11.      user.setId(2 );  
  12.      System.out.println(findUser1(user));  
  13.    }  
  14.    
  15.   static   void  addUser(User user) {  
  16.      String sql = "insert into user(name,birthday, money) values (:name,:birthday,:money) " ;  
  17.      SqlParameterSource ps = new  BeanPropertySqlParameterSource(user);  
  18.      KeyHolder keyHolder = new  GeneratedKeyHolder();  
  19.      named.update(sql, ps, keyHolder);  
  20.      int  id = keyHolder.getKey().intValue();  
  21.      user.setId(id);  
  22.        
  23.      Map map = keyHolder.getKeys();  
  24.    }  
  25.    
  26.   static  User findUser(User user) {  
  27.      String sql = "select id, name, money, birthday    from user "   
  28.          + "where money > :m and id < :id" ;  
  29.      Map params = new  HashMap();  
  30.      // params.put("n", user.getName());   
  31.      params.put("m" , user.getMoney());  
  32.      params.put("id" , user.getId());  
  33.      Object u = named.queryForObject(sql, params, new  BeanPropertyRowMapper(  
  34.          User.class ));  
  35.      return  (User) u;  
  36.    }  
  37.    
  38.   static  User findUser1(User user) {  
  39.      String sql = "select id, name, money, birthday    from user "   
  40.          + "where money > :money and id < :id" ;  
  41.      SqlParameterSource ps = new  BeanPropertySqlParameterSource(user);  
  42.      Object u = named.queryForObject(sql, ps, new  BeanPropertyRowMapper(User. class ));  
  43.      return  (User) u;  
  44.    }  
  45.    
  46. }  



【注意】

1、BeanPropertyRowMapper完成了对象到数据库字段的映射关系, 可以不再使用RowMapper来一一对应起来。如果RowMapper只使用1次,则可以直接使用内部类来完成,而不再需要专门的写一个类。

2、KeyHolder, 其中保存了数据库中操作的主键,取得操作的主键后, 方便对进行操作的记录进行其他动作。



总之:利用反射技术,减少的了不必要的rowmapper,提高了效率

分享到:
评论

相关推荐

    Spring--JdbcTemplate.pdf

    描述中提到的"一图详解(脑图)"意味着文档中可能包含了一个清晰的图示,这个图示将详细展示JdbcTemplate在Spring中的使用过程和相关组件的交互。这样的图示对于理解JdbcTemplate的工作原理以及如何在项目中实际应用它...

    spring-jdbc-4.2.xsd.zip

    《Spring JDBC 4.2.xsd详解》 在Java企业级开发中,Spring框架是不可或缺的一部分,它提供了全面的编程和配置模型,极大地简化了应用的构建和维护。Spring JDBC作为Spring框架的一部分,主要负责数据库操作,使得...

    Spring-JdbcTemplate

    **Spring-JdbcTemplate 知识详解** `Spring-JdbcTemplate` 是 Spring 框架中的一个核心模块,主要用于简化数据库操作,提供了强大的数据访问功能。它通过模板方法设计模式封装了 SQL 的执行,使得开发者无需直接与 ...

    spring-framework-2.5.6

    《Spring框架2.5.6版本详解》 Spring框架,作为Java开发领域中的核心框架之一,自诞生以来就以其强大的功能、优秀的可扩展性和模块化的结构赢得了广大开发者们的青睐。2.5.6版本是Spring在2008年10月发布的一个稳定...

    spring-xx.zip

    《Spring框架核心组件详解》 Spring框架作为Java领域最广泛应用的轻量级开源框架,以其模块化、松耦合的设计理念,为开发者提供了强大的企业级应用开发能力。本压缩包"spring-xx.zip"包含了Spring框架的核心组件,...

    spring-mvc-demo

    【Spring MVC 框架详解】 Spring MVC 是 Spring 框架的一部分,它是一个轻量级的、基于模型-视图-控制器(MVC)设计模式的 Web 应用开发框架。Spring MVC 提供了丰富的功能,使得开发者可以快速、高效地构建高质量...

    spring-framework-reference

    《Spring 框架详解——基于“spring-framework-reference”参考文档》 在Java开发领域,Spring框架无疑是最具影响力和广泛使用的轻量级框架之一。它以其强大的功能、灵活的设计和丰富的生态系统,成为了企业级应用...

    spring-hibernate3.jar.zip

    《Spring与Hibernate集成详解》 在Java开发领域,Spring框架和Hibernate ORM工具是两个非常重要的组件,它们分别处理了应用程序的依赖注入(DI)和对象关系映射(ORM)。Spring作为一个全面的轻量级框架,提供了...

    spring-boot-2.4.x.zip

    《Spring Boot 2.4.x 源码详解与应用实践》 Spring Boot是Java领域一个备受推崇的轻量级框架,它简化了基于Spring的应用程序开发,通过提供默认配置来消除大量的样板代码。在2.4.x版本中,Spring Boot引入了更多...

    Android代码-spring-boot2-learning

    chapter2: 一起来学Spring Boot | 第二篇:Spring Boot配置详解 chapter3: 一起来学Spring Boot | 第四篇:整合Thymeleaf模板 chapter4: 一起来学Spring Boot | 第五篇:使用JdbcTemplate访问数据库 chapter5: ...

    spring-framework-4.1.6.RELEASE-schema.zip

    《Spring Framework 4.1.6.RELEASE Schema详解》 Spring Framework是Java开发中的核心框架,它为构建高质量、可维护、可扩展的应用程序提供了全面的解决方案。在4.1.6.RELEASE版本中,Spring引入了对XML Schema的...

    Spring笔记之整合JdbcTemplate.doc

    ### Spring与JdbcTemplate整合详解 #### 一、JdbcTemplate简介及使用 **1.1 JdbcTemplate概述** JdbcTemplate是Spring框架中的一个重要组成部分,它提供了一种简单而强大的方式来访问数据库,通过封装JDBC API,...

    spring-boot-demo

    《Spring Boot Demo详解》 Spring Boot作为Java领域中备受瞩目的框架,因其简化Spring应用程序的初始搭建以及开发过程而广受赞誉。"spring-boot-demo"项目是一个典型的Spring Boot入门示例,旨在帮助开发者快速理解...

    day4-Spring JdbcTemplate & 声明式事务.md

    ### Spring JdbcTemplate与声明式事务知识点详解 #### JdbcTemplate基本使用概述 JdbcTemplate是Spring框架提供的用于简化JDBC API操作的对象。它通过提供一个高级抽象层来减少编码工作量,并帮助开发者避免处理...

    官方源码 spring-framework-5.3.1.zip

    《Spring Framework 5.3.1官方源码详解》 Spring Framework是Java开发中的一个核心框架,它为构建高效、灵活、可测试的Java应用程序提供了基础。Spring 5.3.1是该框架的一个重要版本,它包含了诸多新特性、性能优化...

    2023版全新SSM框架实战精讲 视频教程 下载下载 因为太大存百度云盘2.zip

    027-spring-ioc-三层架构组件管理介绍和jdbctemplate使用.mp4 028-spring-ioc-三层架构组件管理实战.mp4 029-spring-ioc-基于注解方式ioc配置.mp4 030-spring-ioc-扩展周期方法和作用域注解.mp4 031-spring-ioc-...

    spring-framework-3.0.5.RELEASE-src

    《Spring框架3.0.5.RELEASE源代码详解》 Spring框架是Java开发中的一个核心组件,它以其模块化、可扩展性和强大的依赖注入机制,极大地简化了企业级应用的开发工作。3.0.5.RELEASE是Spring的一个重要版本,它在功能...

    2023版全新SSM框架实战精讲 视频教程 下载下载 因为太大存百度云盘3.zip

    027-spring-ioc-三层架构组件管理介绍和jdbctemplate使用.mp4 028-spring-ioc-三层架构组件管理实战.mp4 029-spring-ioc-基于注解方式ioc配置.mp4 030-spring-ioc-扩展周期方法和作用域注解.mp4 031-spring-ioc-...

Global site tag (gtag.js) - Google Analytics