- 浏览: 640387 次
- 性别:
- 来自: 成都
文章分类
最新评论
-
hsluoyz:
现在新推出了一个权限框架,叫jCasbin(https://g ...
Shiro 权限框架使用总结 -
飕飕飞:
比如说 我用私匙加密一段数据,并加密成功。那签名时用什么生成的 ...
Java使用RSA加密解密签名及校验 -
文艺吧网:
楼主讲的好详细,这里有整套 Shiro demo http:/ ...
Shiro 权限框架使用总结 -
nanshanmu:
333引用[url][*]||||[/flash][/flas ...
SpringMVC中返回值处理 -
变脸小伙:
) 业务类在Spring配置 ...
整合Struts2与Spring以及spring的自动装配
1、JdbcTemplate操作数据库
Spring对数据库的操作在jdbc上面做了深层次的封装,使用spring的注入功能,可以把DataSource注册到
JdbcTemplate之中。同时,为了支持对properties文件的支持,spring提供了类似于EL表达式的方式,把
dataSource.properties的文件参数引入到参数配置之中,<context:property-placeholder
location="classpath:jdbc.properties" />。
实例代码如下:
提供数据源的相关配置信息:jdbc.properties
- driverClassName=org.gjt.mm.mysql.Driver
- url=jdbc\:mysql\://localhost\:3306/stanley?useUnicode\=true&characterEncoding\=UTF-8
- username=root
- password=123456
- initialSize=1
- maxActive=500
- maxIdle=2
- minIdle=1
提供spring的配置文件,将jdbc.properties与JdbcTemplate粘合起来的配置文件:beans.xml
- <?xml version= "1.0" encoding= "UTF-8" ?>
- <beans xmlns="http://www.springframework.org/schema/beans"
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xmlns:context="http://www.springframework.org/schema/context"
- xmlns:aop="http://www.springframework.org/schema/aop"
- xmlns:tx="http://www.springframework.org/schema/tx"
- xsi:schemaLocation="http://www.springframework.org/schema/beans
- http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
- http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
- http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
- http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
- <context:property-placeholder location="classpath:jdbc.properties" />
- <bean id="dataSource" class = "org.apache.commons.dbcp.BasicDataSource" destroy-method= "close" >
- <property name="driverClassName" value= "${driverClassName}" />
- <property name="url" value= "${url}" />
- <property name="username" value= "${username}" />
- <property name="password" value= "${password}" />
- <!-- 连接池启动时的初始值 -->
- <property name="initialSize" value= "${initialSize}" />
- <!-- 连接池的最大值 -->
- <property name="maxActive" value= "${maxActive}" />
- <!-- 最大空闲值.当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,一直减少到maxIdle为止 -->
- <property name="maxIdle" value= "${maxIdle}" />
- <!-- 最小空闲值.当空闲的连接数少于阀值时,连接池就会预申请去一些连接,以免洪峰来时来不及申请 -->
- <property name="minIdle" value= "${minIdle}" />
- </bean>
- <bean id="txManager" class = "org.springframework.jdbc.datasource.DataSourceTransactionManager" >
- <property name="dataSource" ref= "dataSource" />
- </bean>
- <aop:config>
- <aop:pointcut id="transactionPointcut" expression= "execution(* cn.comp.service..*.*(..))" />
- <aop:advisor advice-ref="txAdvice" pointcut-ref= "transactionPointcut" />
- </aop:config>
- <tx:advice id="txAdvice" transaction-manager= "txManager" >
- <tx:attributes>
- <tx:method name="get*" read-only= "true" propagation= "NOT_SUPPORTED" />
- <tx:method name="*" />
- </tx:attributes>
- </tx:advice>
- <bean id="personService" class = "cn.comp.service.impl.PersonServiceBean" >
- <property name="dataSource" ref= "dataSource" />
- </bean>
- </beans>
或者使用获取jdbc相关连接
- <bean name= "dataSource" class = "org.springframework.jdbc.datasource.DriverManagerDataSource" >
- <property name="driverClassName" value= "com.mysql.jdbc.Driver" ></property>
- <property name="url" value= "jdbc:mysql://localhost/dbunit" ></property>
- <property name="password" value= "root" />
- <property name="username" value= "root" />
- </bean>
提供POJO的java类:Person.java
- public class Person {
- private Integer id;
- private String name;
- public Person(){}
- public Person(String name) {
- this .name = name;
- }
- public Integer getId() {
- return id;
- }
- public void setId(Integer id) {
- this .id = id;
- }
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this .name = name;
- }
- }
提供对Person的操作接口:PersonService.java
- public interface PersonService {
- /**
- * 保存person
- * @param person
- */
- public void save(Person person);
- /**
- * 更新person
- * @param person
- */
- public void update(Person person);
- /**
- * 获取person
- * @param personid
- * @return
- */
- public Person getPerson(Integer personid);
- /**
- * 获取所有person
- * @return
- */
- public List<Person> getPersons();
- /**
- * 删除指定id的person
- * @param personid
- */
- public void delete(Integer personid) throws Exception;
- }
提供对接口的实现类:PersonServiceBean.java
- public class PersonServiceBean implements PersonService {
- private JdbcTemplate jdbcTemplate;
- public void setDataSource(DataSource dataSource) {
- this .jdbcTemplate = new JdbcTemplate(dataSource);
- }
- public void delete(Integer personid) throws Exception{
- jdbcTemplate.update("delete from person where id=?" , new Object[]{personid},
- new int []{java.sql.Types.INTEGER});
- }
- public Person getPerson(Integer personid) {
- return (Person)jdbcTemplate.queryForObject( "select * from person where id=?" , new Object[]{personid},
- new int []{java.sql.Types.INTEGER}, new PersonRowMapper());
- }
- @SuppressWarnings ( "unchecked" )
- public List<Person> getPersons() {
- return (List<Person>)jdbcTemplate.query( "select * from person" , new PersonRowMapper());
- }
- public void save(Person person) {
- jdbcTemplate.update("insert into person(name) values(?)" , new Object[]{person.getName()},
- new int []{java.sql.Types.VARCHAR});
- }
- public void update(Person person) {
- jdbcTemplate.update("update person set name=? where id=?" , new Object[]{person.getName(), person.getId()},
- new int []{java.sql.Types.VARCHAR, java.sql.Types.INTEGER});
- }
- }
提供在查询对象时,记录的映射回调类:PersonRowMapper.java
- public class PersonRowMapper implements RowMapper {
- public Object mapRow(ResultSet rs, int index) throws SQLException {
- Person person = new Person(rs.getString( "name" ));
- person.setId(rs.getInt("id" ));
- return person;
- }
- }
【注意】:由于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配置文件中增加对事务的支持:
- <bean id= "txManager" class = "org.springframework.jdbc.datasource.DataSourceTransactionManager" >
- <property name="dataSource" ref= "dataSource" />
- </bean>
- <tx:annotation-driven transaction-manager="txManager" />
- <bean id="personService" class = "cn.comp.service.impl.PersonServiceBean" >
- <property name="dataSource" ref= "dataSource" />
- </bean>
在java程序中显示的指明是否需要事务,当出现运行期异常Exception或一般的异常Exception是否需要回滚
- @Transactional
- public class PersonServiceBean implements PersonService {
- private JdbcTemplate jdbcTemplate;
- public void setDataSource(DataSource dataSource) {
- this .jdbcTemplate = new JdbcTemplate(dataSource);
- }
- // unchecked ,
- // checked
- @Transactional (noRollbackFor=RuntimeException. class )
- public void delete(Integer personid) throws Exception{
- jdbcTemplate.update("delete from person where id=?" , new Object[]{personid},
- new int []{java.sql.Types.INTEGER});
- throw new RuntimeException( "运行期例外" );
- }
- @Transactional (propagation=Propagation.NOT_SUPPORTED)
- public Person getPerson(Integer personid) {
- return (Person)jdbcTemplate.queryForObject( "select * from person where id=?" , new Object[]{personid},
- new int []{java.sql.Types.INTEGER}, new PersonRowMapper());
- }
- @Transactional (propagation=Propagation.NOT_SUPPORTED)
- @SuppressWarnings ( "unchecked" )
- public List<Person> getPersons() {
- return (List<Person>)jdbcTemplate.query( "select * from person" , new PersonRowMapper());
- }
- public void save(Person person) {
- jdbcTemplate.update("insert into person(name) values(?)" , new Object[]{person.getName()},
- new int []{java.sql.Types.VARCHAR});
- }
- public void update(Person person) {
- jdbcTemplate.update("update person set name=? where id=?" , new Object[]{person.getName(), person.getId()},
- new int []{java.sql.Types.VARCHAR, java.sql.Types.INTEGER});
- }
- }
在默认情况下,Spring会对RuntimeException异常进行回滚操作,而对Exception异常不进行回滚。可以显示的什么什么
样的异常需要回滚,什么样的异常不需要回滚, 通过
@Transactional(noRollbackFor=RuntimeException.class)设置要求运行时异常不回滚
或者通过RollbackFor=Exception.class来要求需要捕获的异常回滚。
【注意】Spring对数据库的操作提供了强大的功能,比如RowMapper接口封装数据库字段与Java属性的映射、查询返回List的函数
等,但是里面还要写一堆SQL语句还是比较烦人的,在这部分建议使用ibatis或hibernate来代替,
不知道Spring后期的版本会不会把这个整合到里面。
- <dependency>
- <groupId>com.alibaba.external</groupId>
- <artifactId>sourceforge.spring</artifactId>
- <version>2.5 . 6 </version>
- </dependency>
- <dependency>
- <groupId>com.alibaba.external</groupId>
- <artifactId>jdbc.mysql.mysql-connector</artifactId>
- <version>5.1 . 6 </version>
- </dependency>
- <dependency>
- <groupId>com.alibaba.external</groupId>
- <artifactId>jakarta.commons.dbcp</artifactId>
- <version>1.4 </version>
-
</dependency>
参考文章:http://xiao1227372602.iteye.com/blog/1631268
发表评论
-
context:component-scan扫描使用上的容易忽略的use-default-filters
2015-11-13 21:28 869问题 如下方式可以成功扫描到@Controller注解的Bea ... -
MongoDB Java Driver操作指南
2015-08-04 21:42 2603MongoDB为Java提供了非常丰富的API操作,相比关系 ... -
Spring3自定义环境配置 <beans profile="">
2015-04-22 10:51 1311摘自springside3 Spring 3.1的功能 ... -
json-rpc 1.0规范解读
2015-04-17 14:21 1352JSON可能是这个地球上 ... -
request.getParameter()、request.getInputStream()和request.getReader()
2015-03-30 11:16 3034大家经常 用servlet和jsp, ... -
微信企业号上传下载多媒体文件接口详解演示-java
2015-03-27 15:37 6382企业在使用接口时,对多媒体文件、多媒体消息的获取和调用等操作 ... -
java如何得到GET和POST请求URL和参数列表
2015-03-13 16:28 3158在servlet中GET请求可以通过HttpServletR ... -
关于<context:property-placeholder>的一个有趣现象
2015-01-05 20:09 627先来看下A和B两个模块 A模块和B模块都分别拥有自己的S ... -
spring jms _ activemq
2015-01-05 13:50 948参考链接: http://bsnyderblog.blogsp ... -
读取配置信息
2014-12-29 18:08 895第一种方法是使用java.io和java.util包,缺点是路 ... -
spring 事件机制
2014-11-14 14:17 1000在Spring中已经定义的五 ... -
spring InitializingBean接口
2014-10-27 01:33 666最近工作需要得到sping中的每个事物需要执行的sql, ... -
spring InitializingBean接口
2014-10-27 01:33 992最近工作需要得到sping中的每个事物需要执行的sql,称 ... -
四种常见的 POST 提交数据方式
2014-09-23 11:38 1665HTTP/1.1 协议规定的 HTTP 请求方法有 OPT ... -
使用 Java 配置进行 Spring bean 管理
2014-07-31 17:58 880Spring bean 是使用传统的 XML 方法配置的。在 ... -
怎么使用Servlet 3.0中的上传文件呢?
2014-07-31 15:20 968Spring 3.1开始提供了Servlet 3.0的支持。 ... -
Spring mvc 拓展使用
2014-07-31 15:08 1009原文链接:http://my.oschina.net/u/11 ... -
Spring MVC handler method 参数绑定常用的注解
2014-07-31 10:36 2037参考链接:http://csjava.bl ... -
SpringMVC中使用Interceptor拦截器
2014-06-30 15:18 882SpringMVC 中的Interceptor 拦 ... -
AOP的底层实现-CGLIB动态代理和JDK动态代理
2014-05-04 16:58 1069AOP是目前Spring框架中的 ...
相关推荐
描述中提到的"一图详解(脑图)"意味着文档中可能包含了一个清晰的图示,这个图示将详细展示JdbcTemplate在Spring中的使用过程和相关组件的交互。这样的图示对于理解JdbcTemplate的工作原理以及如何在项目中实际应用它...
《Spring JDBC 4.2.xsd详解》 在Java企业级开发中,Spring框架是不可或缺的一部分,它提供了全面的编程和配置模型,极大地简化了应用的构建和维护。Spring JDBC作为Spring框架的一部分,主要负责数据库操作,使得...
**Spring-JdbcTemplate 知识详解** `Spring-JdbcTemplate` 是 Spring 框架中的一个核心模块,主要用于简化数据库操作,提供了强大的数据访问功能。它通过模板方法设计模式封装了 SQL 的执行,使得开发者无需直接与 ...
《Spring框架2.5.6版本详解》 Spring框架,作为Java开发领域中的核心框架之一,自诞生以来就以其强大的功能、优秀的可扩展性和模块化的结构赢得了广大开发者们的青睐。2.5.6版本是Spring在2008年10月发布的一个稳定...
《Spring框架核心组件详解》 Spring框架作为Java领域最广泛应用的轻量级开源框架,以其模块化、松耦合的设计理念,为开发者提供了强大的企业级应用开发能力。本压缩包"spring-xx.zip"包含了Spring框架的核心组件,...
【Spring MVC 框架详解】 Spring MVC 是 Spring 框架的一部分,它是一个轻量级的、基于模型-视图-控制器(MVC)设计模式的 Web 应用开发框架。Spring MVC 提供了丰富的功能,使得开发者可以快速、高效地构建高质量...
《Spring 框架详解——基于“spring-framework-reference”参考文档》 在Java开发领域,Spring框架无疑是最具影响力和广泛使用的轻量级框架之一。它以其强大的功能、灵活的设计和丰富的生态系统,成为了企业级应用...
《Spring与Hibernate集成详解》 在Java开发领域,Spring框架和Hibernate ORM工具是两个非常重要的组件,它们分别处理了应用程序的依赖注入(DI)和对象关系映射(ORM)。Spring作为一个全面的轻量级框架,提供了...
《Spring Boot 2.4.x 源码详解与应用实践》 Spring Boot是Java领域一个备受推崇的轻量级框架,它简化了基于Spring的应用程序开发,通过提供默认配置来消除大量的样板代码。在2.4.x版本中,Spring Boot引入了更多...
chapter2: 一起来学Spring Boot | 第二篇:Spring Boot配置详解 chapter3: 一起来学Spring Boot | 第四篇:整合Thymeleaf模板 chapter4: 一起来学Spring Boot | 第五篇:使用JdbcTemplate访问数据库 chapter5: ...
《Spring Framework 4.1.6.RELEASE Schema详解》 Spring Framework是Java开发中的核心框架,它为构建高质量、可维护、可扩展的应用程序提供了全面的解决方案。在4.1.6.RELEASE版本中,Spring引入了对XML Schema的...
### Spring与JdbcTemplate整合详解 #### 一、JdbcTemplate简介及使用 **1.1 JdbcTemplate概述** JdbcTemplate是Spring框架中的一个重要组成部分,它提供了一种简单而强大的方式来访问数据库,通过封装JDBC API,...
《Spring Boot Demo详解》 Spring Boot作为Java领域中备受瞩目的框架,因其简化Spring应用程序的初始搭建以及开发过程而广受赞誉。"spring-boot-demo"项目是一个典型的Spring Boot入门示例,旨在帮助开发者快速理解...
### Spring JdbcTemplate与声明式事务知识点详解 #### JdbcTemplate基本使用概述 JdbcTemplate是Spring框架提供的用于简化JDBC API操作的对象。它通过提供一个高级抽象层来减少编码工作量,并帮助开发者避免处理...
《Spring Framework 5.3.1官方源码详解》 Spring Framework是Java开发中的一个核心框架,它为构建高效、灵活、可测试的Java应用程序提供了基础。Spring 5.3.1是该框架的一个重要版本,它包含了诸多新特性、性能优化...
027-spring-ioc-三层架构组件管理介绍和jdbctemplate使用.mp4 028-spring-ioc-三层架构组件管理实战.mp4 029-spring-ioc-基于注解方式ioc配置.mp4 030-spring-ioc-扩展周期方法和作用域注解.mp4 031-spring-ioc-...
《Spring框架3.0.5.RELEASE源代码详解》 Spring框架是Java开发中的一个核心组件,它以其模块化、可扩展性和强大的依赖注入机制,极大地简化了企业级应用的开发工作。3.0.5.RELEASE是Spring的一个重要版本,它在功能...
027-spring-ioc-三层架构组件管理介绍和jdbctemplate使用.mp4 028-spring-ioc-三层架构组件管理实战.mp4 029-spring-ioc-基于注解方式ioc配置.mp4 030-spring-ioc-扩展周期方法和作用域注解.mp4 031-spring-ioc-...