使用Spring+JDBC集成步骤如下:
配置数据源,如:
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close"> <property name="driverClassName" value="org.gjt.mm.mysql.Driver" /> <property name="url" value="jdbc:mysql://localhost:3306/spring?useUnicode=true&characterEncoding=UTF-8" /> <property name="username" value="root" /> <property name="password" value="mysql" /> .....略 </bean>
配置事务。配置事务时,需要在xml配置文件中引入用于声明事务的tx命名空间(如下),事务的配置方式有两种:注解方式和基于XML配置方式。
<beans xmlns="http://www.springframework.org/schema/beans" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:aop="http://www.springframework.org/schema/aop" xmlns:context="http://www.springframework.org/schema/context" 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/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd http://www.springframework.org/schema/aop h ttp://www.springframework.org/schema/aop/spring-aop-2.5.xsd http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd"> </beans>
为了方便,我们使用属性占位符方式配置数据源
<!-- classpath指明在配置文件在类路径下面 --> <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>
jdbc.properties
driverClassName=org.gjt.mm.mysql.Driver url=jdbc\:mysql\://localhost\:3306/spring?useUnicode\=true&characterEncoding\=UTF-8 username=root password=mysql initialSize=1 maxActive=500 maxIdle=2 minIdle=1
采用注解方式配置事务
<bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager"> <property name="dataSource" ref="dataSource" /> </bean> <!– 采用@Transactional注解方式使用事务 --> <tx:annotation-driven transaction-manager="txManager" />
综合上述,spring.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"> <!-- classpath指明在配置文件在类路径下面 --> <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> <tx:annotation-driven transaction-manager="txManager" /> <bean id="personService" class="org.spring.service.impl.PersonServiceBean"> <property name="dataSource" ref="dataSource" /> </bean> </beans>
Person类
package org.spring.bean; 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; } }
PersonService
package org.spring.service; import java.util.List; import org.spring.bean.Person; 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); }
PersonServiceBean
package org.spring.service.impl; import java.util.List; import javax.sql.DataSource; import org.spring.bean.Person; import org.spring.service.PersonService; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.transaction.annotation.Transactional; @Transactional public class PersonServiceBean implements PersonService { private JdbcTemplate jdbcTemplate; public void setDataSource(DataSource dataSource) { this.jdbcTemplate = new JdbcTemplate(dataSource); } public void delete(Integer personid) { 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
package org.spring.service.impl; import java.sql.ResultSet; import java.sql.SQLException; import org.spring.bean.Person; import org.springframework.jdbc.core.RowMapper; 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; } }
测试类
package org.spring.junit; import org.junit.BeforeClass; import org.junit.Test; import org.spring.bean.Person; import org.spring.service.PersonService; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; public class PersonServiceTest { private static PersonService personService; @BeforeClass public static void setUpBeforeClass() throws Exception { try { ApplicationContext cxt = new ClassPathXmlApplicationContext( "spring.xml"); personService = (PersonService) cxt.getBean("personService"); } catch (RuntimeException e) { e.printStackTrace(); } } @Test public void save() { for (int i = 0; i < 5; i++) personService.save(new Person("spring" + i)); } @Test public void getPerson() { Person person = personService.getPerson(3); System.out.println(person.getName()); } @Test public void update() { Person person = personService.getPerson(1); person.setName("xxx"); personService.update(person); } @Test public void delete() { personService.delete(1); } @Test public void getBeans() { for (Person person : personService.getPersons()) { System.out.println(person.getName()); } } }
目录结构如下
相关推荐
这个"spring_JDBC整合包"显然包含了进行Spring JDBC开发所需的全部或大部分依赖库。 在Spring JDBC中,主要涉及以下几个核心概念: 1. **JdbcTemplate**: 这是Spring JDBC的核心接口,提供了一组用于执行SQL语句的...
本示例"Spring mvc、Spring、Spring jdbc 整合 demo"着重展示了Spring框架的三大关键模块:Spring MVC(模型-视图-控制器)、Spring Core以及Spring JDBC的集成与应用。 1. **Spring MVC** Spring MVC是Spring框架...
"spring+jdbc整合"是一个常见的话题,尤其对于初学者而言,理解这两者的结合是提升开发效率的关键。下面我们将详细探讨Spring如何与JDBC进行整合,以及这种整合在实际项目中的应用。 首先,Spring框架通过其JDBC...
本知识点主要聚焦于Spring框架的一个重要组件——Spring JDBC,以及如何将它与MySQL8数据库进行整合,同时考虑了Java 8的新特性。下面我们将深入探讨这个主题。 Spring JDBC模块是Spring框架对Java数据库连接(JDBC...
这个整合Demo是一个学习和实践Spring MVC、Spring和Spring JDBC整合的绝佳案例,它涵盖了Web应用开发的多个层面,从接收用户请求到数据持久化,再到视图的呈现。通过深入研究这个Demo,开发者可以更好地理解和掌握...
《Java开发中的SpringMVC + Spring + SpringJDBC整合详解》 在Java开发领域,Spring框架因其强大的功能和灵活性而备受推崇。SpringMVC、Spring和SpringJDBC是Spring框架中的核心组件,它们的整合使用可以构建出高效...
《Spring MVC + Spring + Spring JDBC 整合实例详解》 在Java Web开发中,Spring框架因其强大的功能和灵活的设计而备受推崇。Spring MVC、Spring核心模块以及Spring JDBC是Spring框架中的三大重要组成部分,它们...
在压缩包中的"复件 SpringJDBC"文件可能包含一个简单的Spring整合JDBC的示例。代码可能包括了配置文件、实体类、DAO接口和其实现。例如,创建一个UserDao接口,使用JdbcTemplate进行用户查询: ```java public ...
在整合Spring MVC、Spring和Spring JDBC的实例中,你可能会看到以下几个关键部分: 1. **配置文件**:包括Spring的主配置文件(如`applicationContext.xml`),其中定义了Bean的配置,包括DataSource、JdbcTemplate...
首先,`spring整合jdbc`指的是Spring JDBC模块,它为JDBC提供了一个简单的抽象层,减少了直接使用JDBC时的繁琐工作,如手动创建和管理数据库连接、处理结果集等。Spring JDBC通过`JdbcTemplate`和`SimpleJdbcInsert`...
Spring MVC、Spring 和 Spring JDBC 是Java开发中广泛使用的三大核心框架,它们的整合为开发者提供了强大的后端服务构建能力。让我们深入探讨这三个组件以及它们如何协同工作实现登录功能。 **Spring 框架** Spring...
这个"SpringMVC + Spring + SpringJDBC整合demo"是一个完整的示例项目,旨在帮助开发者理解如何将这三个框架集成到一个应用中。 **SpringMVC**是Spring框架的一部分,专门用于构建Web应用程序。它提供了模型-视图-...
关于spring与jdbc整合的ppt文档,主要描述了java如何与jdbc整合
标题“spring+jdbc整合jar.rar”表明这是一个关于整合Spring框架与Java数据库连接(JDBC)的资源包,其中包含了运行Spring JDBC操作所需的各种库。描述提到这个压缩包包含的jar文件是全面的,这意味着它应该提供了...
SpringMVC3与SpringJDBC的整合是Java Web开发中常见的技术组合,它允许开发者在后端处理HTTP请求并高效地操作数据库。本项目提供了一个完整的整合实例,涵盖了基本的CRUD(创建、读取、更新、删除)操作,权限过滤...
Spring整合JDBC的配置 Spring框架是 Java 企业级应用开发的标准框架之一,它提供了强大的依赖注入和AOP功能,使得开发者可以更方便地进行企业级应用开发。在实际开发中,我们常常需要将Spring与JDBC集成,以便于...
Phoenix Hbase springjdbc整合 demo Phoenix最早是saleforce的一个开源项目,后来成为Apache基金的顶级项目。 Phoenix是构建在HBase上的一个SQL层,能让我们用标准的JDBC APIs而不是HBase客户端APIs来创建表,插入...
Struts2、Spring和JDBC是Java开发...总结来说,Struts2、Spring和JDBC的整合涉及到多种jar包,包括框架的核心库、数据库驱动、连接池实现以及其他的辅助库。理解这些库的作用并正确配置,是成功整合这三个框架的基础。
**SpringMVC、Spring与SpringJDBC整合详解** 在Java Web开发中,Spring框架因其强大的功能和灵活性而被广泛使用。SpringMVC、Spring和SpringJDBC是Spring框架的三个重要组成部分,它们协同工作,提供了从用户接口到...