`
sarin
  • 浏览: 1759266 次
  • 性别: Icon_minigender_1
  • 来自: 大连
博客专栏
E3b14d1f-4cc5-37dd-b820-b6af951740bc
Spring数据库访问系列...
浏览量:173921
C2083dc5-6474-39e2-993e-263652d27795
Android学习笔记
浏览量:368483
5f40a095-b33c-3e8e-8891-606fcf3b8d27
iBatis开发详解
浏览量:189518
B272a31d-e7bd-3eff-8cc4-c0624ee75fee
Objective-C学习...
浏览量:100080
社区版块
存档分类
最新评论

Spring数据库访问之ORM(三)

阅读更多
    本文接上一篇继续研究。
    之前我们使用的是HibernateTemplate来进行对象的持久化的,其实在DAO实现类中我们还可以使用Hibernate的上下文Session来持久化对象。也就是通过SessionFactory对象的getCurrentSession()对象来获得Session,然后通过Session来进行操作。
    我们调整一下代码:
package org.ourpioneer.course.dao;
import java.util.List;
import org.hibernate.Query;
import org.hibernate.SessionFactory;
import org.ourpioneer.course.bean.Course;
import org.springframework.transaction.annotation.Transactional;
public class CourseDAOImplHibernate implements CourseDAO {
	private SessionFactory sessionFactory;
	public void setSessionFactory(SessionFactory sessionFactory) {
		this.sessionFactory = sessionFactory;
	}
	@Transactional
	public void delete(Course course) {
		sessionFactory.getCurrentSession().delete(course);
	}
	@Transactional(readOnly = true)
	public List<Course> findAll() {
		Query query = sessionFactory.getCurrentSession().createQuery(
				"from Course");
		return query.list();
	}
	@Transactional(readOnly = true)
	public Course findById(Long courseId) {
		return (Course) sessionFactory.getCurrentSession().get(Course.class,
				courseId);
	}
	@Transactional
	public void save(Course course) {
		sessionFactory.getCurrentSession().saveOrUpdate(course);
	}
	@Transactional
	public void update(Course course) {
		sessionFactory.getCurrentSession().update(course);
	}
}

    这里要注意的是所有DAO的方法必须是支持事务的,这可以通过添加Transactional注解来完成,就很简单了,之前也有过介绍。这样就能保证DAO中所有方法都可以在同一个Session,同一个事务内来执行,达到使用事务的效果。
    将代码修改完成后,就要来修改配置文件了:
<tx:annotation-driven />
	<bean id="transactionManager"
	class="org.springframework.orm.hibernate3.HibernateTransactionManager">
		<property name="sessionFactory" ref="sessionFactory" />
	</bean>
	<bean id="courseDaoHibernate" class="org.ourpioneer.course.dao.CourseDAOImplHibernate">
		<property name="sessionFactory" ref="sessionFactory" />
	</bean>

    这样,基于上下文Session的持久化对象就配置完毕了,在示例程序中来执行,就会看到效果。修改测试程序如下:
package org.ourpioneer.course;
import java.util.GregorianCalendar;
import java.util.List;
import org.ourpioneer.course.bean.Course;
import org.ourpioneer.course.dao.CourseDAO;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
public class Demo {
	public static void main(String[] args) {
		ApplicationContext ctx = new ClassPathXmlApplicationContext(
			 	"classpath:applicationContext.xml");
		CourseDAO courseDAO = (CourseDAO) ctx.getBean("courseDaoHibernate");
		Course course = new Course();
		course.setTitle("Spring ORM");
		course.setStartDate(new GregorianCalendar(2011, 2, 1).getTime());
		course.setEndDate(new GregorianCalendar(2011, 3, 1).getTime());
		course.setFee(100);
		courseDAO.save(course);
		List<Course> courses = courseDAO.findAll();
		Long courseId = courses.get(0).getId();
		course = courseDAO.findById(courseId);
		System.out.println(course);
		course.setFee(200);
		courseDAO.update(course);
		System.out.println(course);
		courseDAO.delete(course);
	}
}

    在控制台,我们可以看到如下输出:

    这种方式和使用HibernateTemplate有的不同是它们对异常的处理。HibernateTemplate会将异常统一翻译成Spring的数据访问异常体系中的某个异常,而我们使用上下文的Session时,抛出的就不是Spring的异常,而是HibernateException,如果我们还想看到Spring的异常体系,就需要做点设置,当然这也很简单。
    在DAO实现类上加@Respository注解,并且注册一个PersistenceExceptionTranslationPostProcessor实例即可。在Spring的配置文件中,我们加入如下内容:
<bean class="org.springframework.dao.annotation.PersistenceExceptionTranslationPostProcessor"></bean>

    这是使用Hibernate的情况,那么使用JPA的情况和这个类似,我们来修改JPA的DAO实现类:
package org.ourpioneer.course.dao;
import java.util.List;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import javax.persistence.Query;
import org.ourpioneer.course.bean.Course;
import org.springframework.transaction.annotation.Transactional;
public class CourseDAOImplJPA implements CourseDAO {
	@PersistenceContext
	private EntityManager entityManager;
	@Transactional
	public void delete(Course course) {
		entityManager.remove(entityManager.merge(course));
	}
	@Transactional(readOnly = true)
	public List<Course> findAll() {
		Query query = entityManager.createQuery("from Course");
		return query.getResultList();
	}
	@Transactional(readOnly = true)
	public Course findById(Long courseId) {
		return entityManager.find(Course.class, courseId);
	}
	@Transactional
	public void save(Course course) {
		entityManager.merge(course);
	}
	@Transactional
	public void update(Course course) {
		entityManager.merge(course);
	}
}

    这里我们使用注解来声明了EntityManager,那么需要在配置文件中在声明一个PersistenceAnnotationBeanPostProcessor实例就好了。配置文件修改为:
	<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
		<property name="entityManagerFactory" ref="entityManagerFactory" />
	</bean>
	<bean id="courseDaoJPA" class="org.ourpioneer.course.dao.CourseDAOImplJPA" />
	<bean class="org.springframework.orm.jpa.support.PersistenceAnnotationBeanPostProcessor"></bean>

    之后,将测试程序中的getBean()换成courseDaoJPA即可。
    和HibernateTemplate一样,JpaTemplate也会将异常翻译为Spring的数据访问异常,而如果改成entityManagerFactory之后,异常就会变成Java SE的异常,比如非法参数,非法状态等异常。若要继续使用Spring的异常体系,那么要为JPA的DAO实现类加上@Repository注解,然后注册PersistenceExceptionTranslationPostProcessor实例。
    至此,我们的Spring的ORM部分已经全部介绍完了,源代码随附件发布。后续将介绍Spring对iBatis的支持
  • 大小: 73.8 KB
15
6
分享到:
评论

相关推荐

    Spring数据库访问(HSQL)(三)

    在"Spring数据库访问(HSQL)(三)"这个主题中,博主可能详细讲解了如何配置Spring与HSQL的集成,以及如何利用Spring的数据访问组件进行数据库操作。 首先,我们需要了解Spring的JdbcTemplate和HibernateTemplate...

    访问数据库基本封装(spring/hibernate/ibatis)

    首先,Spring框架以其强大的依赖注入和面向切面编程闻名,它不仅是一个全面的后端开发框架,还提供了多种数据库访问方式。Spring JDBC模块提供了对JDBC的简单封装,使得编写SQL和处理结果集变得更简洁。同时,Spring...

    spring-orm.jar

    Spring ORM的主要目标是简化数据库操作,通过提供一种声明式的方式来管理数据持久化,使得开发者能够更加专注于业务逻辑而不是底层的数据库访问。它支持多种ORM框架,包括Hibernate、JPA、iBatis等,让开发者可以...

    spring-orm源码

    通过深入研究Spring-ORM的源码,开发者不仅可以提高对Spring框架的理解,还能学习到数据库访问的最佳实践,以及如何高效地集成和使用不同的ORM框架。这对于任何希望优化和扩展数据访问层的Java开发者来说都是宝贵的...

    org.springframework.orm.jar.zip

    三、Spring ORM事务管理 Spring提供了声明式事务管理,允许开发者在配置文件中定义事务边界,而无需在业务逻辑代码中显式处理事务。这种方式既保持了代码的清晰,又实现了事务的统一管理。同时,Spring还支持编程式...

    org.springframework.orm.hibernate3.LocalSessionFactoryBean

    这些支持服务简化了数据库访问,并且使得与不同的ORM工具进行集成变得更加容易。 2. **Hibernate**:一个开放源码的对象关系映射框架,允许开发者将Java对象映射到数据库表中。它简化了持久化层的开发工作,使...

    Spring整合其他ORM框架

    1. **Spring 整合 Hibernate**:Hibernate 是一款流行的 ORM 框架,它允许开发者用 Java 对象直接操作数据库。Spring 提供的 HibernateTemplate 或 SessionFactoryBean 可以帮助简化 Hibernate 的配置和使用。通过 ...

    Spring数据库访问之iBatis

    为了丰富博客专栏【Spring数据库访问系列】的内容,完善Spring数据库访问的体系,现在我们介绍Spring对iBatis的支持。相对于Hibernate等ORM框架的全自动SQL,那么iBatis则属于半自动化的ORM框架,我们需要编写SQL...

    spring学习:hibernate orm集成

    Spring JDBC提供了一种模板化的JDBC访问方式,简化了数据库操作,而Spring ORM则集成了各种ORM框架,包括Hibernate,使得我们可以方便地在Spring环境中使用这些ORM工具。 集成Hibernate到Spring项目中,我们需要...

    基于Spring与Hibernate的数据库访问技术研究

    基于Spring与Hibernate的数据库访问技术,通过将Spring的依赖注入和事务管理与Hibernate的ORM特性相结合,不仅简化了数据持久层的开发,提高了代码的可维护性和可测试性,还极大地提升了系统的性能和响应速度。...

    spring-orm.src.zip net

    Spring-ORM是Spring框架的重要组成部分,专注于数据库操作和对象关系映射(ORM)的集成。它为开发者提供了与多种ORM框架(如Hibernate、JPA、MyBatis等)协同工作的能力,极大地简化了Java应用中的数据访问层。在...

    快速学习-Spring Data JPA 之 ORM概述

    第1章 ORM概述[了解] ...当实现一个应用程序时(不使用O/R Mapping),我们可能会写特别多数据访问层的代码,从数据库保存数据、修改数据、删除数据,而这些代码都是重复的。而使用ORM则会大大减少

    Spring-MF-ORM

    标题“Spring-MF-ORM”暗示我们关注的是Spring框架与对象关系映射(ORM)的结合,特别是关于在Java环境中如何使用Spring来管理数据库操作。ORM是Object-Relational Mapping的缩写,它允许开发者使用面向对象的方式来...

    Spring所需jar包包括数据库连接池

    数据访问/集成模块则提供了与数据库交互的支持,包括JDBC、ORM(Object-Relational Mapping)框架如Hibernate或MyBatis等。 总的来说,Spring框架通过IOC和AOP等机制,提供了强大的组件管理和代码解耦能力。而C3P0...

    跟我学Spring3(8.1)对ORM的支持之概述Java

    Spring通过其数据访问抽象层,提供了统一的API和事务管理,使得在不同的ORM框架间切换变得容易。 1. Hibernate:Hibernate是Java领域中最受欢迎的ORM框架之一,Spring3提供了对它的深度支持。Spring的...

    档案信息管理系统 spring mvc、 hiberntate、 spring 数据库和包完整

    该系统采用了Spring MVC、Hibernate和Spring三大技术栈,这些都是Java开发中非常重要的框架。 1. **Spring MVC**:Spring MVC是Spring框架的一部分,专门用于构建Web应用程序。它采用模型-视图-控制器(MVC)设计...

    Spring与非关系数据库搭配使用

    首先,Spring框架提供了强大的数据访问抽象层,使得开发者可以轻松地与各种数据库交互,包括关系型数据库如MySQL、Oracle,以及非关系型数据库如MongoDB、Cassandra等。Spring Data项目是这一抽象层的核心,它为多种...

    数据库访问组件

    数据库访问组件是软件开发中一个至关重要的部分,它允许应用程序与各种类型的数据库进行交互,以存储、检索和处理数据。这些组件通常包含了多种接口、类和工具,为开发者提供了便捷的方式来执行SQL查询、事务管理、...

Global site tag (gtag.js) - Google Analytics