使用Spring+JDBC组合步骤如下:
一、首先:配置数据源如:
在配置数据源时,先添加spring开发能力,添加库文件{
Spring 2.5 AOP Libraries
Spring 2.5 Core Libraries
Spring 2.5 Persistence Core Libraries
Spring 2.5 Persistence JDBC Libraries //这个可不要忘了加
}
注意: ${}是把dataSource的属性放到properties文档里面
<bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName" value="${driverClassName}"> </property> <property name="url" value="${url}"> </property> <property name="username" value="${username}"></property> <property name="password" value="${password}"></property> <!-- 连接池启动时的初始值 --> <property name="initialSize" value="${initialSize}"></property> <!-- 连接池的最大值 --> <property name="maxActive" value="${maxActive}"></property> <!-- 最大空间值、当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,直至减少的maxIdle为止 --> <property name="maxIdle" value="${maxIdle}"></property> <!-- 最小空间值,当空间的连接数少于阀值时,连接池就会预申请一些连接,以免洪峰来时 来不及申请 --> <property name="minIdle" value="${minIdle}"></property> </bean>
可以把配置放到属性文件里面去 jdbc.properties
driverClassName=com.mysql.jdbc.Driver url=jdbc\:mysql\://localhost\:3306/test?useUnicode\=true&characterEncoding\=UTF-8 username=root password=fly initialSize=1 maxActive=500 maxIdle=2 minIdle=1
在spring容器中加入下面代码
<context:property-placeholder location="classpath:jdbc.properties"/>
二、配置事务,配置事务时,需要在xml配置文件中引入用于声明事务的tx命名空间,
事务的配置有两种:注解方式和基于XML配置方式
在这里我采用“注解方式”如: <bean id="txManager"
class="org.springframework.jdbc.datasource.DataSourceTransactionManager"
abstract="false" lazy-init="default"
dependency-check="default">
<property name="dataSource"> //要求注入数据源,dataSource是我们自己定义的数据源
<ref bean="dataSource" />
</property>
</bean>
我们采用注解方式,
<!-- 采用@Transaction注解方式使用事务 -->
<tx:annotation-driven transaction-manager="txManager"/> //transaction-manager属性指定事务管理器
首先添加tx:的命名空间:红色的是tx的命名空间
<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 http://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>
经过这几步的配置,我们已经配置好了spring到jdbc的集成
spring容器中的全部配置:如下:可以直接拷贝使用
<?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: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 http://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"> <context:property-placeholder location="classpath:jdbc.properties"/> <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"> <property name="driverClassName" value="${driverClassName}"> </property> <property name="url" value="${url}"> </property> <property name="username" value="${username}"></property> <property name="password" value="${password}"></property> <!-- 连接池启动时的初始值 --> <property name="initialSize" value="${initialSize}"></property> <!-- 连接池的最大值 --> <property name="maxActive" value="${maxActive}"></property> <!-- 最大空间值、当经过一个高峰时间后,连接池可以慢慢将已经用不到的连接慢慢释放一部分,直至减少的maxIdle为止 --> <property name="maxIdle" value="${maxIdle}"></property> <!-- 最小空间值,当空间的连接数少于阀值时,连接池就会预申请一些连接,以免洪峰来时 来不及申请 --> <property name="minIdle" value="${minIdle}"></property> </bean> <bean id="txManager" class="org.springframework.jdbc.datasource.DataSourceTransactionManager" abstract="false" lazy-init="default" dependency-check="default"> <property name="dataSource"> <ref bean="dataSource" /> </property> </bean> <tx:annotation-driven transaction-manager="txManager"/> <bean id="personService" class="com.xt.service.impl.PersonServiceBean"> <property name="dataSource" ref="dataSource" /> </bean> </beans>
三、接下来,建表,编写业务逻辑,增删查改
建表:表名:person
字段:id Intege primary key autoincrment 自增
字段:name varchar(20)
首先:定义接口:PersionService
package com.xt.service; import java.util.List; import com.xt.bean.Person; public interface PersonService { public void save(Person person); public void update(Person person); public Person getPerson(Integer personid); public List<Person> getPersons(); public void delete(Integer personid); }
建立bean类 :Person package com.xt.bean; public class Person { public Integer id; public 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接口,创建实现类PersonServiceBean package com.xt.service.impl; import java.util.List; import javax.sql.DataSource; import org.springframework.jdbc.core.JdbcTemplate; import org.springframework.transaction.annotation.Transactional; import com.xt.bean.Person; import com.xt.service.PersonService; @Transactional public class PersonServiceBean implements PersonService { private JdbcTemplate jdbcTemplate; //我们使用spring提供的JdbcTemplate类进行管理, public void setDataSource(DataSource dataSource) { this.jdbcTemplate = new JdbcTemplate(dataSource); } @Transactional(rollbackFor=Exception.class) 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 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()}, new int[]{java.sql.Types.VARCHAR,java.sql.Types.INTEGER}); } } 还需要一个回调接口PersonRowMapper package com.xt.service.impl; import java.sql.ResultSet; import java.sql.SQLException; import org.springframework.jdbc.core.RowMapper; import com.xt.bean.Person; 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; } } 把PersonServiceBean交给spring,把下面的代码加到spring容器管理 <bean id="personService" class="com.xt.service.impl.PersonServiceBean"> <property name="dataSource" ref="dataSource" /> //获取数据源 </bean> 然后,我们来进行测试建立一个单元测试 package junit.test; import org.junit.BeforeClass; import org.junit.Test; import org.springframework.context.ApplicationContext; import org.springframework.context.support.ClassPathXmlApplicationContext; import com.xt.bean.Person; import com.xt.service.PersonService; public class PersonServiceBeanTest { private static PersonService personService; @BeforeClass public static void setUpBeforeClass() throws Exception { ApplicationContext cxt = new ClassPathXmlApplicationContext( "/applicationContext.xml"); personService = (PersonService) cxt.getBean("personService"); } @Test public void save() { for (int i = 0; i < 5; i++) { personService.save(new Person("众志成城" + i)); } } @Test public void update() { Person person = personService.getPerson(1); person.setName("我是大好人"); System.out.println(person.getName()); } @Test public void getPerson() { Person person = personService.getPerson(1); System.out.println(person.getName()); } @Test public void delete() { personService.delete(2); } @Test public void getBeans() { for (Person p : personService.getPersons()) System.out.println(p.getId() + " = " + p.getName()); } }
相关推荐
Struts、Spring和Jdbc的集成是其中的一个经典组合,它们各自的优势互补,共同构建出高效、可维护的Web应用系统。下面将详细阐述这一集成过程的关键步骤。 #### 一、建立WEB PROJECT 首先,通过MyEclipse创建一个新...
Struts1、Spring 2.5.6 和 JDBC 是经典的Java Web开发技术组合,它们各自在应用程序架构中扮演着不同的角色。Struts1是MVC(Model-View-Controller)框架,Spring则是一个全面的轻量级应用框架,而JDBC(Java ...
标题中的“spring+mybatis+jdbc.rar”表明这是一个基于Java技术栈的项目,主要使用了Spring、MyBatis和JDBC三个核心组件。这是一套常见的企业级应用框架,用于构建后端服务。 1. Spring:Spring是Java领域的一个...
SpringMVC、Spring和JDBC是Java Web开发中常用的三个技术框架,它们组合在一起形成了SSM(Spring MVC、Spring、MyBatis)架构的一种变体。在这个项目中,"SpringMVC+Spring+JDBC环境"指的是利用这些技术构建一个完整...
总结起来,使用Maven在Eclipse中搭建Spring+Spring MVC+Hibernate框架涉及以下步骤: 1. 创建Maven项目,配置`pom.xml`。 2. 配置Spring和Spring MVC的XML配置文件。 3. 设置Hibernate配置,创建实体类。 4. 构建Web...
《Spring MVC + Quartz 整合实现...这一组合不仅提供了强大的任务调度能力,还结合了Spring MVC的Web处理优势,使得任务管理更加便捷直观。在实际项目中,这种方案已被广泛采用,为企业的自动化运维提供了有力支撑。
以上就是使用`Gradle`、`Spring`、`Spring MVC`、`Spring JDBC`和`MySQL`实现单表数据操作的基本步骤。这个过程中,我们利用了Spring Boot的自动配置特性,减少了大量手动配置的工作,同时通过Spring Data JPA简化了...
SSM框架,即Spring、SpringMVC和MyBatis的集成,是Java开发中常见的Web应用程序框架组合。这个框架集合提供了完整的后端解决方案,涵盖了依赖注入(DI)、面向切面编程(AOP)、模型视图控制器(MVC)以及持久层操作...
Spring、SpringMVC和Mybatis是Java开发中最常用的三大开源框架,它们的整合使用,通常被称为SSM框架。这个框架组合提供了完整的后端服务解决方案,包括依赖注入(DI)、面向切面编程(AOP)、模型-视图-控制器(MVC...
SSM(Spring+SpringMVC+Mybatis)是Java开发中常用的三大开源框架的组合,广泛应用于企业级Web应用开发。本文将深入解析SSM框架的整合过程及其核心概念。 首先,Spring框架是整个SSM中的基石,它提供了一个全面的...
在Java开发领域,Spring、SpringMVC和MyBatis框架的组合,简称SSM,是构建Web应用程序的常用技术栈。IntelliJ IDEA作为一款强大的Java集成开发环境,提供了便捷的工具来搭建这样的项目。以下是详细步骤: 1. **安装...
在上述过程中,"v512工作室_刘伟_Hibernate与Struts2和Spring组合开发.pdf"这份文档可能会提供详细的步骤和示例,帮助你更深入地理解和实践Struts2+Spring+Hibernate的整合开发。记得根据实际情况调整配置,以适应你...
SSM框架是Java Web开发中常用的一种组合,由Spring、SpringMVC和Mybatis三大组件构成。这个框架整合为开发者提供了高效、灵活的开发环境,适用于构建复杂的企业级应用。 **1. Spring框架** Spring是Java领域的一个...
本项目框架“Spring+Mybatis+Mysql”就是一种常见的、高效的Java Web开发组合,适用于初学者和专业人士进行学习和参考。下面将详细讲解这个框架的核心组成部分及其作用。 1. **Spring框架**:Spring是一个开源的...
SSM框架,即Spring、SpringMVC和MyBatis的集成,是Java Web开发中常用的一种轻量级框架组合。这三种技术各有其特点,结合使用可以构建出高效、灵活的Web应用程序。下面我们将深入探讨这三个框架的原理、整合过程以及...
其中,“SSH”即Struts+Spring+Hibernate组合是最为经典且广泛使用的集成方案之一。 ##### 1.1 框架 在Java Web应用开发过程中,合理选择和利用框架是非常重要的。一个好的框架不仅可以帮助开发人员减少重复工作,...
【Spring+SpringMVC+Mybatis+Maven项目】是一个典型的Java Web开发框架组合,用于构建高效、可扩展的企业级应用程序。在这个项目中,Spring作为核心容器管理组件,SpringMVC处理HTTP请求和响应,Mybatis则负责数据库...
本文将深入探讨如何结合使用Spring、Ibatis(现称为MyBatis)以及WebWork这三个流行的Java开发框架来构建高效的应用程序。具体而言,我们将重点关注如何配置这些框架以实现良好的集成效果,并特别关注在Oracle数据库...
- 在数据访问层中,使用Spring JDBC的JdbcTemplate或NamedParameterJdbcTemplate来执行SQL语句。 - 在Service层,通过AOP实现事务管理,确保数据一致性。 - 编写Controller,接收并处理HTTP请求,调用Service层...
本实例关注的是“ibatis+Spring+struts2”的整合,这是一个经典的Java Web开发组合,用于实现数据访问、业务逻辑控制和用户界面交互。下面我们将深入探讨这三个组件及其整合的关键知识点。 1. **iBATIS**:iBATIS...