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

Spring--JdbcTemplate详解-1

    博客分类:
  • SSH
 
阅读更多

1、JdbcTemplate操作数据库

Spring对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到 JdbcTemplate之中。同时,为了支持对properties文件的支持,spring提供了类似于EL表达式的方式,把 dataSource.properties的文件参数引入到参数配置之中,<context:property-placeholder location="classpath:jdbc.properties" />。



实例代码如下:

提供数据源的相关配置信息:jdbc.properties

Java代码  收藏代码
  1. driverClassName=org.gjt.mm.mysql.Driver  
  2.  url=jdbc\:mysql\://localhost\:3306/stanley?useUnicode\=true&characterEncoding\=UTF-8   
  3.  username=root  
  4.  password=123456   
  5.  initialSize=1   
  6.  maxActive=500   
  7.  maxIdle=2   
  8.  minIdle=1   


提供spring的配置文件,将jdbc.properties与JdbcTemplate粘合起来的配置文件:beans.xml

Java代码  收藏代码
  1. <?xml version= "1.0"  encoding= "UTF-8" ?>  
  2.  <beans xmlns="http://www.springframework.org/schema/beans"   
  3.               xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"   
  4.               xmlns:context="http://www.springframework.org/schema/context"    
  5.              xmlns:aop="http://www.springframework.org/schema/aop"   
  6.               xmlns:tx="http://www.springframework.org/schema/tx"   
  7.               xsi:schemaLocation="http://www.springframework.org/schema/beans   
  8.                       http://www.springframework.org/schema/beans/spring-beans-2.5.xsd   
  9.                       http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd   
  10.                       http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd   
  11.                       http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">   
  12.    
  13.     <context:property-placeholder location="classpath:jdbc.properties" />  
  14.      <bean id="dataSource"   class = "org.apache.commons.dbcp.BasicDataSource"  destroy-method= "close" >  
  15.           <property name="driverClassName"  value= "${driverClassName}" />  
  16.           <property name="url"  value= "${url}" />  
  17.           <property name="username"  value= "${username}" />  
  18.           <property name="password"  value= "${password}" />  
  19.              <!-- 连接池启动时的初始值 -->  
  20.       <property name="initialSize"  value= "${initialSize}" />  
  21.       <!-- 连接池的最大值 -->  
  22.       <property name="maxActive"  value= "${maxActive}" />  
  23.       <!-- 最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 -->  
  24.       <property name="maxIdle"  value= "${maxIdle}" />  
  25.       <!--    最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 -->  
  26.       <property name="minIdle"  value= "${minIdle}" />  
  27.      </bean>  
  28.    
  29.   <bean id="txManager"   class = "org.springframework.jdbc.datasource.DataSourceTransactionManager" >  
  30.              <property name="dataSource"  ref= "dataSource" />  
  31.          </bean>  
  32.    
  33.   <aop:config>  
  34.          <aop:pointcut id="transactionPointcut"  expression= "execution(* cn.comp.service..*.*(..))" />  
  35.          <aop:advisor advice-ref="txAdvice"  pointcut-ref= "transactionPointcut" />  
  36.    </aop:config>   
  37.   <tx:advice id="txAdvice"  transaction-manager= "txManager" >  
  38.          <tx:attributes>  
  39.              <tx:method name="get*"  read-only= "true"  propagation= "NOT_SUPPORTED" />  
  40.              <tx:method name="*" />  
  41.          </tx:attributes>  
  42.    </tx:advice>  
  43.    
  44.   <bean id="personService"   class = "cn.comp.service.impl.PersonServiceBean" >  
  45.      <property name="dataSource"  ref= "dataSource" />  
  46.    </bean>  
  47.  </beans>  



或者使用获取jdbc相关连接

Java代码  收藏代码
  1. <bean name= "dataSource"   class = "org.springframework.jdbc.datasource.DriverManagerDataSource" >  
  2.      <property name="driverClassName"  value= "com.mysql.jdbc.Driver" ></property>  
  3.      <property name="url"  value= "jdbc:mysql://localhost/dbunit" ></property>  
  4.      <property name="password"  value= "root"  />  
  5.      <property name="username"  value= "root"  />  
  6.    </bean>  


提供POJO的java类:Person.java

Java代码  收藏代码
  1. public   class  Person {  
  2.    private  Integer id;  
  3.    private  String name;  
  4.      
  5.    public  Person(){}  
  6.      
  7.    public  Person(String name) {  
  8.      this .name = name;  
  9.    }  
  10.    public  Integer getId() {  
  11.      return  id;  
  12.    }  
  13.    public   void  setId(Integer id) {  
  14.      this .id = id;  
  15.    }  
  16.    public  String getName() {  
  17.      return  name;  
  18.    }  
  19.    public   void  setName(String name) {  
  20.      this .name = name;  
  21.    }  
  22.  }  


提供对Person的操作接口:PersonService.java

Java代码  收藏代码
  1. public   interface  PersonService {  
  2.    /**  
  3.      * 保存person  
  4.      * @param person  
  5.      */   
  6.    public   void  save(Person person);  
  7.    /**  
  8.      * 更新person  
  9.      * @param person  
  10.      */   
  11.    public   void  update(Person person);  
  12.    /**  
  13.      * 获取person  
  14.      * @param personid  
  15.      * @return  
  16.      */   
  17.    public  Person getPerson(Integer personid);  
  18.    /**  
  19.      * 获取所有person  
  20.      * @return  
  21.      */   
  22.    public  List<Person> getPersons();  
  23.    /**  
  24.      * 删除指定id的person  
  25.      * @param personid  
  26.      */   
  27.    public   void  delete(Integer personid)  throws  Exception;  
  28.  }  


提供对接口的实现类:PersonServiceBean.java

Java代码  收藏代码
  1. public   class  PersonServiceBean  implements  PersonService {  
  2.    private  JdbcTemplate jdbcTemplate;  
  3.      
  4.    public   void  setDataSource(DataSource dataSource) {  
  5.      this .jdbcTemplate =  new  JdbcTemplate(dataSource);  
  6.    }  
  7.      
  8.    public   void  delete(Integer personid)  throws  Exception{  
  9.      jdbcTemplate.update("delete from person where id=?" new  Object[]{personid},  
  10.          new   int []{java.sql.Types.INTEGER});  
  11.    }  
  12.      
  13.    public  Person getPerson(Integer personid) {      
  14.      return  (Person)jdbcTemplate.queryForObject( "select * from person where id=?" new  Object[]{personid},   
  15.         new   int []{java.sql.Types.INTEGER},  new  PersonRowMapper());  
  16.    }  
  17.    
  18.   @SuppressWarnings ( "unchecked" )  
  19.    public  List<Person> getPersons() {  
  20.      return  (List<Person>)jdbcTemplate.query( "select * from person" new  PersonRowMapper());  
  21.    }  
  22.    
  23.   public   void  save(Person person) {  
  24.      jdbcTemplate.update("insert into person(name) values(?)" new  Object[]{person.getName()},  
  25.          new   int []{java.sql.Types.VARCHAR});  
  26.    }  
  27.    
  28.   public   void  update(Person person) {  
  29.      jdbcTemplate.update("update person set name=? where id=?" new  Object[]{person.getName(), person.getId()},  
  30.          new   int []{java.sql.Types.VARCHAR, java.sql.Types.INTEGER});  
  31.    }  
  32.  }  


提供在查询对象时,记录的映射回调类:PersonRowMapper.java

Java代码  收藏代码
  1. public   class  PersonRowMapper  implements  RowMapper {  
  2.    
  3.   public  Object mapRow(ResultSet rs,  int  index)  throws  SQLException {  
  4.      Person person = new  Person(rs.getString( "name" ));  
  5.      person.setId(rs.getInt("id" ));  
  6.      return  person;  
  7.    }  
  8.  }  



【注意】:由于dbcp的jar包对common-pool和commons-collections的jar包有依赖,所有需要把他们一起引入 到工程中。【 commons-dbcp-1.2.1.jar, commons-pool-1.2.jar, commons-collections-3.1.jar】, 参考文档《JDBC高级部分》:http://tianya23.blog.51cto.com/1081650/270849




2、JdbcTemplate事务

事务的操作首先要通过配置文件,取得spring的支持, 再在java程序中显示的使用@Transactional注解来使用事务操作。



在xml配置文件中增加对事务的支持:

Java代码  收藏代码
  1. <bean id= "txManager"   class = "org.springframework.jdbc.datasource.DataSourceTransactionManager" >  
  2.              <property name="dataSource"  ref= "dataSource" />  
  3.          </bean>  
  4.    <tx:annotation-driven transaction-manager="txManager" />  
  5.      
  6.    <bean id="personService"   class = "cn.comp.service.impl.PersonServiceBean" >  
  7.      <property name="dataSource"  ref= "dataSource" />  
  8.    </bean>  



在java程序中显示的指明是否需要事务,当出现运行期异常Exception或一般的异常Exception是否需要回滚

Java代码  收藏代码
  1. @Transactional   
  2.  public   class  PersonServiceBean  implements  PersonService {  
  3.    private  JdbcTemplate jdbcTemplate;  
  4.      
  5.    public   void  setDataSource(DataSource dataSource) {  
  6.      this .jdbcTemplate =  new  JdbcTemplate(dataSource);  
  7.    }  
  8.    // unchecked ,   
  9.    // checked   
  10.    @Transactional (noRollbackFor=RuntimeException. class )  
  11.    public   void  delete(Integer personid)  throws  Exception{  
  12.      jdbcTemplate.update("delete from person where id=?" new  Object[]{personid},  
  13.          new   int []{java.sql.Types.INTEGER});  
  14.      throw   new  RuntimeException( "运行期例外" );  
  15.    }  
  16.    @Transactional (propagation=Propagation.NOT_SUPPORTED)  
  17.    public  Person getPerson(Integer personid) {      
  18.      return  (Person)jdbcTemplate.queryForObject( "select * from person where id=?" new  Object[]{personid},   
  19.         new   int []{java.sql.Types.INTEGER},  new  PersonRowMapper());  
  20.    }  
  21.    
  22.   @Transactional (propagation=Propagation.NOT_SUPPORTED)  
  23.    @SuppressWarnings ( "unchecked" )  
  24.    public  List<Person> getPersons() {  
  25.      return  (List<Person>)jdbcTemplate.query( "select * from person" new  PersonRowMapper());  
  26.    }  
  27.    
  28.   public   void  save(Person person) {  
  29.      jdbcTemplate.update("insert into person(name) values(?)" new  Object[]{person.getName()},  
  30.          new   int []{java.sql.Types.VARCHAR});  
  31.    }  
  32.    
  33.   public   void  update(Person person) {  
  34.      jdbcTemplate.update("update person set name=? where id=?" new  Object[]{person.getName(), person.getId()},  
  35.          new   int []{java.sql.Types.VARCHAR, java.sql.Types.INTEGER});  
  36.    }  
  37.  }  



在默认情况下,Spring会对RuntimeException异常进行回滚操作,而对Exception异常不进行回滚。可以显示的什么什么 样的异常需要回滚,什么样的异常不需要回滚, 通过 @Transactional(noRollbackFor=RuntimeException.class)设置要求运行时异常不回滚 或者通过RollbackFor=Exception.class来要求需要捕获的异常回滚。



【注意】Spring对数据库的操作提供了强大的功能,比如RowMapper接口封装数据库字段与Java属性的映射、查询返回List的函数 等,但是里面还要写一堆SQL语句还是比较烦人的,在这部分建议使用ibatis或hibernate来代替, 不知道Spring后期的版本会不会把这个整合到里面。

Java代码  收藏代码
  1. <dependency>  
  2.        <groupId>com.alibaba.external</groupId>  
  3.        <artifactId>sourceforge.spring</artifactId>  
  4.        <version>2.5 . 6 </version>  
  5.      </dependency>  
  6.      <dependency>  
  7.        <groupId>com.alibaba.external</groupId>  
  8.        <artifactId>jdbc.mysql.mysql-connector</artifactId>  
  9.        <version>5.1 . 6 </version>  
  10.      </dependency>  
  11.      <dependency>  
  12.        <groupId>com.alibaba.external</groupId>  
  13.        <artifactId>jakarta.commons.dbcp</artifactId>  
  14.        <version>1.4 </version>  
  15.      </dependency> 

 

参考文章:http://xiao1227372602.iteye.com/blog/1631268

分享到:
评论

相关推荐

    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框架实战精讲 视频教程 下载下载 因为太大存百度云盘1.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