`
在水伊方
  • 浏览: 111501 次
  • 性别: Icon_minigender_1
  • 来自: 福州
社区版块
存档分类
最新评论

Spring与JDBC整合

 
阅读更多

使用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&amp;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());
		}
	}
}

 

目录结构如下

  • 大小: 51.1 KB
分享到:
评论

相关推荐

    spring_JDBC整合包

    这个"spring_JDBC整合包"显然包含了进行Spring JDBC开发所需的全部或大部分依赖库。 在Spring JDBC中,主要涉及以下几个核心概念: 1. **JdbcTemplate**: 这是Spring JDBC的核心接口,提供了一组用于执行SQL语句的...

    Spring mvc、 Spring、 Spring jdbc 整合 demo

    本示例"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框架通过其JDBC...

    Spring-JDBC整合-MySQL8、java8版本

    本知识点主要聚焦于Spring框架的一个重要组件——Spring JDBC,以及如何将它与MySQL8数据库进行整合,同时考虑了Java 8的新特性。下面我们将深入探讨这个主题。 Spring JDBC模块是Spring框架对Java数据库连接(JDBC...

    Spring mvc + Spring + Spring jdbc 整合 demo

    这个整合Demo是一个学习和实践Spring MVC、Spring和Spring JDBC整合的绝佳案例,它涵盖了Web应用开发的多个层面,从接收用户请求到数据持久化,再到视图的呈现。通过深入研究这个Demo,开发者可以更好地理解和掌握...

    java开发之SpringMVC + Spring + SpringJDBC整合.zip

    《Java开发中的SpringMVC + Spring + SpringJDBC整合详解》 在Java开发领域,Spring框架因其强大的功能和灵活性而备受推崇。SpringMVC、Spring和SpringJDBC是Spring框架中的核心组件,它们的整合使用可以构建出高效...

    Spring mvc + Spring + Spring jdbc 整合实例源码

    《Spring MVC + Spring + Spring JDBC 整合实例详解》 在Java Web开发中,Spring框架因其强大的功能和灵活的设计而备受推崇。Spring MVC、Spring核心模块以及Spring JDBC是Spring框架中的三大重要组成部分,它们...

    spring 整合JDBC 原创代码

    在压缩包中的"复件 SpringJDBC"文件可能包含一个简单的Spring整合JDBC的示例。代码可能包括了配置文件、实体类、DAO接口和其实现。例如,创建一个UserDao接口,使用JdbcTemplate进行用户查询: ```java public ...

    Spring mvc、 Spring、 Spring jdbc 整合实例源码

    在整合Spring MVC、Spring和Spring JDBC的实例中,你可能会看到以下几个关键部分: 1. **配置文件**:包括Spring的主配置文件(如`applicationContext.xml`),其中定义了Bean的配置,包括DataSource、JdbcTemplate...

    spring 整合jdbc时用到的jar包

    首先,`spring整合jdbc`指的是Spring JDBC模块,它为JDBC提供了一个简单的抽象层,减少了直接使用JDBC时的繁琐工作,如手动创建和管理数据库连接、处理结果集等。Spring JDBC通过`JdbcTemplate`和`SimpleJdbcInsert`...

    SpringMVC+Spring+SpringJDBC整合框架

    Spring MVC、Spring 和 Spring JDBC 是Java开发中广泛使用的三大核心框架,它们的整合为开发者提供了强大的后端服务构建能力。让我们深入探讨这三个组件以及它们如何协同工作实现登录功能。 **Spring 框架** Spring...

    SpringMVC + Spring + SpringJDBC整合demo

    这个"SpringMVC + Spring + SpringJDBC整合demo"是一个完整的示例项目,旨在帮助开发者理解如何将这三个框架集成到一个应用中。 **SpringMVC**是Spring框架的一部分,专门用于构建Web应用程序。它提供了模型-视图-...

    spring与jdbc

    关于spring与jdbc整合的ppt文档,主要描述了java如何与jdbc整合

    spring+jdbc整合jar.rar

    标题“spring+jdbc整合jar.rar”表明这是一个关于整合Spring框架与Java数据库连接(JDBC)的资源包,其中包含了运行Spring JDBC操作所需的各种库。描述提到这个压缩包包含的jar文件是全面的,这意味着它应该提供了...

    SpringMVC3 + SpringJDBC整合 源码。

    SpringMVC3与SpringJDBC的整合是Java Web开发中常见的技术组合,它允许开发者在后端处理HTTP请求并高效地操作数据库。本项目提供了一个完整的整合实例,涵盖了基本的CRUD(创建、读取、更新、删除)操作,权限过滤...

    spring整合jdbc的配置

    Spring整合JDBC的配置 Spring框架是 Java 企业级应用开发的标准框架之一,它提供了强大的依赖注入和AOP功能,使得开发者可以更方便地进行企业级应用开发。在实际开发中,我们常常需要将Spring与JDBC集成,以便于...

    Phoenix Hbase springjdbc整合 demo

    Phoenix Hbase springjdbc整合 demo Phoenix最早是saleforce的一个开源项目,后来成为Apache基金的顶级项目。 Phoenix是构建在HBase上的一个SQL层,能让我们用标准的JDBC APIs而不是HBase客户端APIs来创建表,插入...

    struts2,spring,jdbc整合所需jar包

    Struts2、Spring和JDBC是Java开发...总结来说,Struts2、Spring和JDBC的整合涉及到多种jar包,包括框架的核心库、数据库驱动、连接池实现以及其他的辅助库。理解这些库的作用并正确配置,是成功整合这三个框架的基础。

    SpringMVC+Spring+SpringJDBC

    **SpringMVC、Spring与SpringJDBC整合详解** 在Java Web开发中,Spring框架因其强大的功能和灵活性而被广泛使用。SpringMVC、Spring和SpringJDBC是Spring框架的三个重要组成部分,它们协同工作,提供了从用户接口到...

Global site tag (gtag.js) - Google Analytics