- 浏览: 1757054 次
- 性别:
- 来自: 大连
博客专栏
-
Spring数据库访问系列...
浏览量:173676
-
Android学习笔记
浏览量:368148
-
iBatis开发详解
浏览量:189276
-
Objective-C学习...
浏览量:99851
最新评论
-
iLidy:
引用[/c
Hibernate持久化对象的生命周期详解 -
fengzigogo:
您好,有这个项目架构的源码下载地址吗?
一种Java Web应用开发框架的构建(基于Struts2+Spring+FreeMarker)之一 -
spring_springmvc:
可以参考最新的文档:如何在eclipse jee中检出项目并转 ...
用Maven构建Java Web开发环境(Jetty容器)之二 -
springdata_springmvc:
spring mvc demo教程源代码下载,地址:http: ...
Spring 3之MVC & Security简单整合开发(二) -
赵庆辉:
看帖回复是美德,楼主讲的很清晰明了,看了豁然开朗.
Java String对象的经典问题(new String())
本文接上一篇继续来研究Spring的ORM模块。
现在我们来看如何在Spring中配置ORM资源工厂,也就是在Spring中使用ORM框架。仍然以Hibernate为例来说明,要引入spring-orm和spring-context模块来做测试。首先我们可以修改一下DAO实现类的写法,因为用了Spring,就不用显式来new对象了,那么对于Hibernate的SessionFactory,使用注入的方式来进行配置,修改CourseDAOImpl类,如下设置:
去掉构造方法,为sessionFactory提供get方法即可。之后就是配置Spring了,很简单,要配置courseDao和sessionFactory:
把Hibernate配置对象的映射文件加上,之后修改测试方法,从Spring的容器中获取对象就可以了:
此时,我们还依赖Hibernate的配置文件,那么完全可以把Hibernate中的配置信息移入Spring之中,因为Spring的ORM模块完全支持Hibernate,可以如下进行,我们使用C3P0作为连接池:
将数据库的基本信息配置好后,数据源的配置就完成了。下面是配置Hibernate:
这里我们将实体映射一起配置进来,使用了*通配符,并配置了基本的Hibernate属性,比如方言,显示sql语句和自动建表。剩下的就是DAO的配置了,它不用做什么修改,仍然注入sessionFactory即可,然后执行测试:
从中可以看到启动信息和Hibernate生成的SQL语句。除了使用Hibernate的实体映射文件外,我们还可以使用注解,之前已经在Course持久化类中添加了注解,那么我们就来配置使用注解的方式,很简单,只需修改Spring中的Hibernate SessionFactory配置即可,如下:
这样就使用在持久化类中的注解信息而不需要单独编写HBM映射文件了,执行测试,结果是一样的。当然,在Spring中,还可以使用JPA的EntityManager来进行数据的持久化操作,那么又如何来进行呢?和前面介绍的类似,首先在JPA的DAO实现类中修改EntityManager的配置方式,使用注入来进行:
同理,修改Spring的配置文件,配置EntityManagerFactory,如下:
因为配置了persistenceUnitName,那么不要忘记了在META-INF目录下的persistence.xml文件,其中是这么写的:
因为还用到了hibernate.cfg.xml,不过要将mapping的映射信息全部去掉,之后的courseDaoJPA配置就很简单了:
在测试程序的ctx.getBean方法中换成courseDaoJPA就可以获得JPA的DAO实现对象了,从而进行数据库操作,这也非常简单。如果不使用hibernate的配置文件,那么需要对JPA进行如下的配置:
将数据源注入进来,并配置一些数据库方言,显示sql和生成ddl的信息,最后精简一下persistence.xml文件中的内容:
已经不需要再使用Hibernate的配置文件了,这样就可以了,再次执行测试程序,就可以得到如下输出信息:
在JDBC模块中,Spring的JDBC模板简化了SQL的操作,使得使用SQL非常简便,不需要很多的代码就能完成数据库操作,同样,在ORM模块中,Spring的模板技术也有应用,这里我们主要来看Hibernate模板和JPA模板技术。使用HibernateTemplate非常简单,在DAO的实现类中进行注入即可,使用Hibernate模板为我们提供的方法来执行ORM操作,非常的简便:
其中使用了注解进行事务说明,就不用写在配置文件中了,编写好代码,要让Spring容器知道我们的做法,进行如下配置:
使用tx前缀,只需加上相应的命名空间说明即可,这也很简单。修改主程序:
运行主程序,就可以看到执行效果了:
相对于HibernateTemplate,JpaTemplate也可以实现相同功能,我们来看如下代码:
这里不能忘了delete方法需要首先将脱管态的对象变为持久态的才能进行操作,否则就会发生异常。同样,对于配置文件,也要做响应的调整:
这样,我们修改测试程序中getBean获得的对象,就可以测试程序了,这都非常简单了。这里我们扩展说一点,使用了HibernateTemplate或jpaTemplate后,如果想获取Session或EntityManager,那么可以这么操作:hibernateTemplate.getSessionFactory().getCurrentSession(),对于JPA则是:jpaTemplate.getEntityManager(),除此之外,我们还可以使用他们的execute()方法来执行操作:
JPA的则是:
以上我们是在DAO实现类中直接注入模板来进行操作的,当然我们还可以让实现类继承各自的DaoSupport类来获得模板进行操作,这很简单,我们来看:
同时修改配置文件:
当然,也可以给该类注入HibernateTemplate,看一下该类的源码即可参照使用对应的实例进行注入了,这都很简单,JPA的修改也是相似的:
同时,将配置文件修改为:
下一篇将继续介绍Spring对ORM的支持。
空指针的问题应该还是在哪块儿没有生成对象,所以引用不到,Spring中一定要注入进来。可能很小的地方我们忽略了。
是我没有说清楚,之前的配置有了,那么后面为了省略就没有再提,可能对于不了解的人会产生误解。也感谢您的说明。
现在我们来看如何在Spring中配置ORM资源工厂,也就是在Spring中使用ORM框架。仍然以Hibernate为例来说明,要引入spring-orm和spring-context模块来做测试。首先我们可以修改一下DAO实现类的写法,因为用了Spring,就不用显式来new对象了,那么对于Hibernate的SessionFactory,使用注入的方式来进行配置,修改CourseDAOImpl类,如下设置:
private SessionFactory sessionFactory; public void setSessionFactory(SessionFactory sessionFactory) { this.sessionFactory = sessionFactory; }
去掉构造方法,为sessionFactory提供get方法即可。之后就是配置Spring了,很简单,要配置courseDao和sessionFactory:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="configLocation" value="classpath:hibernate.cfg.xml" /> </bean> <bean id="courseDao" class="org.ourpioneer.course.dao.CourseDAOImpl"> <property name="sessionFactory" ref="sessionFactory"></property> </bean>
把Hibernate配置对象的映射文件加上,之后修改测试方法,从Spring的容器中获取对象就可以了:
ApplicationContext ctx = new ClassPathXmlApplicationContext( "classpath:applicationContext.xml"); CourseDAO courseDAO = (CourseDAO) ctx.getBean("courseDao");
此时,我们还依赖Hibernate的配置文件,那么完全可以把Hibernate中的配置信息移入Spring之中,因为Spring的ORM模块完全支持Hibernate,可以如下进行,我们使用C3P0作为连接池:
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource" scope="singleton" destroy-method="close"> <property name="driverClass" value="com.mysql.jdbc.Driver" /> <property name="jdbcUrl" value="jdbc:mysql:///test" /> <property name="user" value="root" /> <property name="password" value="123" /> </bean>
将数据库的基本信息配置好后,数据源的配置就完成了。下面是配置Hibernate:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.LocalSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="mappingLocations" value="classpath:org/ourpioneer/course/hbm/*.hbm.xml" /> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property> </bean>
这里我们将实体映射一起配置进来,使用了*通配符,并配置了基本的Hibernate属性,比如方言,显示sql语句和自动建表。剩下的就是DAO的配置了,它不用做什么修改,仍然注入sessionFactory即可,然后执行测试:
从中可以看到启动信息和Hibernate生成的SQL语句。除了使用Hibernate的实体映射文件外,我们还可以使用注解,之前已经在Course持久化类中添加了注解,那么我们就来配置使用注解的方式,很简单,只需修改Spring中的Hibernate SessionFactory配置即可,如下:
<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean"> <property name="dataSource" ref="dataSource" /> <property name="annotatedClasses"> <list> <value>org.ourpioneer.course.bean.Course</value> </list> </property> <property name="hibernateProperties"> <props> <prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop> <prop key="hibernate.show_sql">true</prop> <prop key="hibernate.hbm2ddl.auto">update</prop> </props> </property> </bean>
这样就使用在持久化类中的注解信息而不需要单独编写HBM映射文件了,执行测试,结果是一样的。当然,在Spring中,还可以使用JPA的EntityManager来进行数据的持久化操作,那么又如何来进行呢?和前面介绍的类似,首先在JPA的DAO实现类中修改EntityManager的配置方式,使用注入来进行:
private EntityManagerFactory entityManagerFactory; public void setEntityManagerFactory( EntityManagerFactory entityManagerFactory) { this.entityManagerFactory = entityManagerFactory; }
同理,修改Spring的配置文件,配置EntityManagerFactory,如下:
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalEntityManagerFactoryBean"> <property name="persistenceUnitName" value="course" /> </bean>
因为配置了persistenceUnitName,那么不要忘记了在META-INF目录下的persistence.xml文件,其中是这么写的:
<persistence-unit name="course"> <properties> <property name="hibernate.ejb.cfgfile" value="/hibernate.cfg.xml" /> </properties> </persistence-unit>
因为还用到了hibernate.cfg.xml,不过要将mapping的映射信息全部去掉,之后的courseDaoJPA配置就很简单了:
<bean id="courseDaoJPA" class="org.ourpioneer.course.dao.CourseDAOImplJPA"> <property name="entityManagerFactory" ref="entityManagerFactory" /> </bean>
在测试程序的ctx.getBean方法中换成courseDaoJPA就可以获得JPA的DAO实现对象了,从而进行数据库操作,这也非常简单。如果不使用hibernate的配置文件,那么需要对JPA进行如下的配置:
<bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean"> <property name="persistenceUnitName" value="course" /> <property name="dataSource" ref="dataSource" /> <property name="jpaVendorAdapter"> <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"> <property name="databasePlatform" value="org.hibernate.dialect.MySQLDialect" /> <property name="showSql" value="true" /> <property name="generateDdl" value="true" /> </bean> </property> </bean>
将数据源注入进来,并配置一些数据库方言,显示sql和生成ddl的信息,最后精简一下persistence.xml文件中的内容:
<persistence-unit name="course" />
已经不需要再使用Hibernate的配置文件了,这样就可以了,再次执行测试程序,就可以得到如下输出信息:
在JDBC模块中,Spring的JDBC模板简化了SQL的操作,使得使用SQL非常简便,不需要很多的代码就能完成数据库操作,同样,在ORM模块中,Spring的模板技术也有应用,这里我们主要来看Hibernate模板和JPA模板技术。使用HibernateTemplate非常简单,在DAO的实现类中进行注入即可,使用Hibernate模板为我们提供的方法来执行ORM操作,非常的简便:
package org.ourpioneer.course.dao; import java.util.List; import org.ourpioneer.course.bean.Course; import org.springframework.orm.hibernate3.HibernateTemplate; import org.springframework.transaction.annotation.Transactional; public class CourseDAOImplHibernate implements CourseDAO { private HibernateTemplate hibernateTemplate; public void setHibernateTemplate(HibernateTemplate hibernateTemplate) { this.hibernateTemplate = hibernateTemplate; } @Transactional public void delete(Course course) { hibernateTemplate.delete(course); } @Transactional(readOnly = true) public List<Course> findAll() { return hibernateTemplate.find("from Course"); } @Transactional(readOnly = true) public Course findById(Long courseId) { return (Course) hibernateTemplate.get(Course.class, courseId); } @Transactional public void save(Course course) { hibernateTemplate.save(course); } @Transactional public void update(Course course) { hibernateTemplate.update(course); } }
其中使用了注解进行事务说明,就不用写在配置文件中了,编写好代码,要让Spring容器知道我们的做法,进行如下配置:
<tx:annotation-driven /> <bean id="transactionManager" class="org.springframework.orm.hibernate3.HibernateTransactionManager"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate"> <property name="sessionFactory" ref="sessionFactory" /> </bean> <bean id="courseDaoHibernate" class="org.ourpioneer.course.dao.CourseDAOImplHibernate"> <property name="hibernateTemplate" ref="hibernateTemplate" /> </bean>
使用tx前缀,只需加上相应的命名空间说明即可,这也很简单。修改主程序:
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, 1, 1).getTime()); course.setEndDate(new GregorianCalendar(2011, 2, 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); courseDAO.delete(course); } }
运行主程序,就可以看到执行效果了:
相对于HibernateTemplate,JpaTemplate也可以实现相同功能,我们来看如下代码:
package org.ourpioneer.course.dao; import java.util.List; import org.ourpioneer.course.bean.Course; import org.springframework.orm.jpa.JpaTemplate; import org.springframework.transaction.annotation.Transactional; public class CourseDAOImplJPA implements CourseDAO { private JpaTemplate jpaTemplate; public void setJpaTemplate(JpaTemplate jpaTemplate) { this.jpaTemplate = jpaTemplate; } @Transactional public void delete(Course course) { jpaTemplate.remove(jpaTemplate.merge(course)); } @Transactional(readOnly = true) public List<Course> findAll() { return jpaTemplate.find("from Course"); } @Transactional(readOnly = true) public Course findById(Long courseId) { return jpaTemplate.find(Course.class, courseId); } @Transactional public void save(Course course) { jpaTemplate.merge(course); } @Transactional public void update(Course course) { jpaTemplate.merge(course); } }
这里不能忘了delete方法需要首先将脱管态的对象变为持久态的才能进行操作,否则就会发生异常。同样,对于配置文件,也要做响应的调整:
<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager"> <property name="entityManagerFactory" ref="entityManagerFactory" /> </bean> <bean id="jpaTemplate" class="org.springframework.orm.jpa.JpaTemplate"> <property name="entityManagerFactory" ref="entityManagerFactory" /> </bean> <bean id="courseDaoJPA" class="org.ourpioneer.course.dao.CourseDAOImplJPA"> <property name="jpaTemplate" ref="jpaTemplate" /> </bean>
这样,我们修改测试程序中getBean获得的对象,就可以测试程序了,这都非常简单了。这里我们扩展说一点,使用了HibernateTemplate或jpaTemplate后,如果想获取Session或EntityManager,那么可以这么操作:hibernateTemplate.getSessionFactory().getCurrentSession(),对于JPA则是:jpaTemplate.getEntityManager(),除此之外,我们还可以使用他们的execute()方法来执行操作:
hibernateTemplate.execute(new HibernateCallback() { public Object doInHibernate(Session session) throws HibernateException,SQLException { } };
JPA的则是:
jpaTemplate.execute(new JpaCallback() { public Object doInJpa(EntityManager em) throws PersistenceException { return null; } });
以上我们是在DAO实现类中直接注入模板来进行操作的,当然我们还可以让实现类继承各自的DaoSupport类来获得模板进行操作,这很简单,我们来看:
package org.ourpioneer.course.dao; import java.util.List; import org.ourpioneer.course.bean.Course; import org.springframework.orm.hibernate3.support.HibernateDaoSupport; import org.springframework.transaction.annotation.Transactional; public class CourseDAOImplHibernate extends HibernateDaoSupport implements CourseDAO { @Transactional public void delete(Course course) { getHibernateTemplate().delete(course); } @Transactional(readOnly = true) public List<Course> findAll() { return getHibernateTemplate().find("from Course"); } @Transactional(readOnly = true) public Course findById(Long courseId) { return (Course) getHibernateTemplate().get(Course.class, courseId); } @Transactional public void save(Course course) { getHibernateTemplate().save(course); } @Transactional public void update(Course course) { getHibernateTemplate().update(course); } }
同时修改配置文件:
<bean id="courseDaoHibernate" class="org.ourpioneer.course.dao.CourseDAOImplHibernate"> <property name="sessionFactory" ref="sessionFactory" /> </bean>
当然,也可以给该类注入HibernateTemplate,看一下该类的源码即可参照使用对应的实例进行注入了,这都很简单,JPA的修改也是相似的:
package org.ourpioneer.course.dao; import java.util.List; import org.ourpioneer.course.bean.Course; import org.springframework.orm.jpa.support.JpaDaoSupport; import org.springframework.transaction.annotation.Transactional; public class CourseDAOImplJPA extends JpaDaoSupport implements CourseDAO { @Transactional public void delete(Course course) { getJpaTemplate().remove(getJpaTemplate().merge(course)); } @Transactional(readOnly = true) public List<Course> findAll() { return getJpaTemplate().find("from Course"); } @Transactional(readOnly = true) public Course findById(Long courseId) { return getJpaTemplate().find(Course.class, courseId); } @Transactional public void save(Course course) { getJpaTemplate().merge(course); } @Transactional public void update(Course course) { getJpaTemplate().merge(course); } }
同时,将配置文件修改为:
<bean id="courseDaoJPA" class="org.ourpioneer.course.dao.CourseDAOImplJPA"> <property name="entityManagerFactory" ref="entityManagerFactory" /> </bean>
下一篇将继续介绍Spring对ORM的支持。
评论
6 楼
sarin
2011-03-08
ceci.lia 写道
如果调用getJpaTemplate().getEntityManager.merge(course),就应该有问题了。会抛出NullPointerException,这是我这里抛出的问题。
不过还是感谢sarin的耐心回答。
哎,没办法了,还是用JPA的@PersistenceContext的annotation来设置EntityManager的实例了。
不过还是感谢sarin的耐心回答。
哎,没办法了,还是用JPA的@PersistenceContext的annotation来设置EntityManager的实例了。
空指针的问题应该还是在哪块儿没有生成对象,所以引用不到,Spring中一定要注入进来。可能很小的地方我们忽略了。
5 楼
ceci.lia
2011-03-08
如果调用getJpaTemplate().getEntityManager.merge(course),就应该有问题了。会抛出NullPointerException,这是我这里抛出的问题。
不过还是感谢sarin的耐心回答。
哎,没办法了,还是用JPA的@PersistenceContext的annotation来设置EntityManager的实例了。
不过还是感谢sarin的耐心回答。
哎,没办法了,还是用JPA的@PersistenceContext的annotation来设置EntityManager的实例了。
4 楼
sarin
2011-03-08
persistence-unit
配置EntityManagerFactory 配置persistence-unit,若使用ORM框架,还是Hibernate为好,毕竟JPA底层还是参考了Hibernate。
整理时我没有发现不完整的地方,二者都是对比说明的,而且所有测试全部通过。
ceci.lia 写道
sarin请教一下:你说的配置是EntityManager的配置?还是EntityManagerFactory的配置?
如果直接注入EntityManager实例到IoC容器并且配置依赖,那么getEntityManager就不会返回空。如果只是配置了EntityManagerFactory的依赖,那么getEntityManager依然会返回为空。Spring没有像HibernateTemplate的getSession方法那样实现。
对于直接注入JpaTemplate实例没有测试过,应该也是不行的。
这是Spring框架对于JPA实现存在不完整的情况。还望sarin兄帮忙确认下?
如果直接注入EntityManager实例到IoC容器并且配置依赖,那么getEntityManager就不会返回空。如果只是配置了EntityManagerFactory的依赖,那么getEntityManager依然会返回为空。Spring没有像HibernateTemplate的getSession方法那样实现。
对于直接注入JpaTemplate实例没有测试过,应该也是不行的。
这是Spring框架对于JPA实现存在不完整的情况。还望sarin兄帮忙确认下?
配置EntityManagerFactory 配置persistence-unit,若使用ORM框架,还是Hibernate为好,毕竟JPA底层还是参考了Hibernate。
整理时我没有发现不完整的地方,二者都是对比说明的,而且所有测试全部通过。
3 楼
ceci.lia
2011-03-08
sarin请教一下:你说的配置是EntityManager的配置?还是EntityManagerFactory的配置?
如果直接注入EntityManager实例到IoC容器并且配置依赖,那么getEntityManager就不会返回空。如果只是配置了EntityManagerFactory的依赖,那么getEntityManager依然会返回为空。Spring没有像HibernateTemplate的getSession方法那样实现。
对于直接注入JpaTemplate实例没有测试过,应该也是不行的。
这是Spring框架对于JPA实现存在不完整的情况。还望sarin兄帮忙确认下?
如果直接注入EntityManager实例到IoC容器并且配置依赖,那么getEntityManager就不会返回空。如果只是配置了EntityManagerFactory的依赖,那么getEntityManager依然会返回为空。Spring没有像HibernateTemplate的getSession方法那样实现。
对于直接注入JpaTemplate实例没有测试过,应该也是不行的。
这是Spring框架对于JPA实现存在不完整的情况。还望sarin兄帮忙确认下?
2 楼
sarin
2011-03-07
ceci.lia 写道
引用
对于JPA则是:jpaTemplate.getEntityManager()
这句应该是不对的。JpaTemplate.getEntityManager只会返回null,如果在xml中配置了entityManager的依赖,就能正确返回。这是因为实现getEntityManager的JpaAccessor类只会返回注入的EntityManager的实例。而HibernateTemplate中实现了getSession的方法,所以才可以返回。从我看到的API来看,貌似EntityManager被限制在Spring的框架中。当然除非通过EntityManagerFactory来创建EntityManager的实例,获取继承JpaTemplate来获得对EntityManagerFactoryAccessor中的getTransactionalEntityManager方法的调用
是我没有说清楚,之前的配置有了,那么后面为了省略就没有再提,可能对于不了解的人会产生误解。也感谢您的说明。
1 楼
ceci.lia
2011-03-07
引用
对于JPA则是:jpaTemplate.getEntityManager()
这句应该是不对的。JpaTemplate.getEntityManager只会返回null,如果在xml中配置了entityManager的依赖,就能正确返回。这是因为实现getEntityManager的JpaAccessor类只会返回注入的EntityManager的实例。而HibernateTemplate中实现了getSession的方法,所以才可以返回。从我看到的API来看,貌似EntityManager被限制在Spring的框架中。当然除非通过EntityManagerFactory来创建EntityManager的实例,获取继承JpaTemplate来获得对EntityManagerFactoryAccessor中的getTransactionalEntityManager方法的调用发表评论
-
iBatis操作DDL和映射继承
2012-09-09 21:46 9266本文系iBatis开发详解系列文章之iBatis操作D ... -
iBatis查询复杂集合
2012-09-04 20:23 15750本文系iBatis开发详解系列文章之在iBatis查询 ... -
iBatis中使用XML
2012-08-29 19:57 7699本文系iBatis开发详解系列文章之在iBatis中使 ... -
iBatis执行非查询语句(CRUD,函数和过程)
2012-08-26 21:40 9324CRUD操作中除了查询操作,其他都统一称为更新操作,因 ... -
Spring数据库访问之iBatis(二)
2012-06-10 13:56 5795接上文,我们继续来研究Spring和iBatis的整合 ... -
Spring数据库访问之iBatis(一)
2012-01-02 18:45 15990为了丰富博客专栏【Spring数据库访问系列】的内容, ... -
我的视频教程《中小企业OA系统》
2011-07-29 22:27 7749经过5个月的制作,和华章合作的《中小企业OA系统》Ja ... -
iBatis分页(基于Struts2和Freemarker)
2011-05-02 10:05 13114之前介绍过基于Hibernate分页的原理和设计,这里 ... -
Spring数据库访问之ORM(三)
2011-03-02 20:35 17618本文接上一篇继续研究。 之前我们使用的是Hib ... -
Spring数据库访问之ORM(一)
2011-01-27 10:54 30807Spring数据库访问中另外一大模块就是ORM,ORM ... -
Spring数据库访问之异常处理
2011-01-19 10:29 27509使用JDBC API时,很 ... -
Spring数据库访问(HSQL)(四)
2011-01-16 21:49 14567本文接上一篇继续研究Spring的JDBC模板。 ... -
Spring数据库访问(HSQL)(三)
2011-01-13 10:07 13439本文接上一篇继续研究JDBC模板。 之前说的都 ... -
Spring数据库访问(HSQL)(二)
2011-01-11 11:27 10730上一篇我们介绍了 ... -
Spring数据库访问(HSQL)(一)
2011-01-09 23:34 13835本部分主要介绍Spring的JDBC模板,JDBC模板 ... -
Spring 3之MVC & Security简单整合开发(三)
2010-12-03 19:04 22067本文接上一篇继续深入研究Security框架。 ... -
Spring 3之MVC & Security简单整合开发(二)
2010-12-01 20:29 60089本文接上一篇继续 ... -
Spring 3之MVC & Security简单整合开发(一)
2010-11-30 22:00 42627Spring的MVC模块是一种简洁的Web应用框架,实 ... -
iBatis查询select详解
2010-08-07 12:19 40529<select>是iBatis已经映射的语 ... -
iBatis查询API
2010-07-31 13:04 17692先说点基础的内容 ...
相关推荐
总结,Spring数据库访问中的ORM技术是企业级应用开发的重要组成部分。通过Spring对JPA、Hibernate、MyBatis等ORM框架的集成,我们可以轻松地在Java应用中进行数据库操作。同时,Spring提供的事务管理和数据源连接池...
首先,Spring框架以其强大的依赖注入和面向切面编程闻名,它不仅是一个全面的后端开发框架,还提供了多种数据库访问方式。Spring JDBC模块提供了对JDBC的简单封装,使得编写SQL和处理结果集变得更简洁。同时,Spring...
Spring ORM的主要目标是简化数据库操作,通过提供一种声明式的方式来管理数据持久化,使得开发者能够更加专注于业务逻辑而不是底层的数据库访问。它支持多种ORM框架,包括Hibernate、JPA、iBatis等,让开发者可以...
通过深入研究Spring-ORM的源码,开发者不仅可以提高对Spring框架的理解,还能学习到数据库访问的最佳实践,以及如何高效地集成和使用不同的ORM框架。这对于任何希望优化和扩展数据访问层的Java开发者来说都是宝贵的...
Spring ORM模块就是Spring框架对ORM技术的支持,它提供了与Hibernate、JPA、iBatis等主流ORM框架的集成,简化了数据访问层的开发。 二、Spring ORM核心组件 1. Hibernate支持:Spring提供了全面的Hibernate支持,...
在"Spring数据库访问(HSQL)(三)"这个主题中,博主可能详细讲解了如何配置Spring与HSQL的集成,以及如何利用Spring的数据访问组件进行数据库操作。 首先,我们需要了解Spring的JdbcTemplate和HibernateTemplate...
1. **Spring 整合 Hibernate**:Hibernate 是一款流行的 ORM 框架,它允许开发者用 Java 对象直接操作数据库。Spring 提供的 HibernateTemplate 或 SessionFactoryBean 可以帮助简化 Hibernate 的配置和使用。通过 ...
这些支持服务简化了数据库访问,并且使得与不同的ORM工具进行集成变得更加容易。 2. **Hibernate**:一个开放源码的对象关系映射框架,允许开发者将Java对象映射到数据库表中。它简化了持久化层的开发工作,使...
为了丰富博客专栏【Spring数据库访问系列】的内容,完善Spring数据库访问的体系,现在我们介绍Spring对iBatis的支持。相对于Hibernate等ORM框架的全自动SQL,那么iBatis则属于半自动化的ORM框架,我们需要编写SQL...
Spring JDBC提供了一种模板化的JDBC访问方式,简化了数据库操作,而Spring ORM则集成了各种ORM框架,包括Hibernate,使得我们可以方便地在Spring环境中使用这些ORM工具。 集成Hibernate到Spring项目中,我们需要...
Spring框架通过提供高级的JDBC支持,简化了数据库访问代码的编写。 1. **数据源配置**:Spring允许配置数据源,这样就封装了数据库连接的基本信息,并进行了优化处理。这种方式不仅可以提高性能,还能够减少代码量...
Spring-ORM是Spring框架的重要组成部分,专注于数据库操作和对象关系映射(ORM)的集成。它为开发者提供了与多种ORM框架(如Hibernate、JPA、MyBatis等)协同工作的能力,极大地简化了Java应用中的数据访问层。在...
第1章 ORM概述[了解] ...当实现一个应用程序时(不使用O/R Mapping),我们可能会写特别多数据访问层的代码,从数据库保存数据、修改数据、删除数据,而这些代码都是重复的。而使用ORM则会大大减少
基于Spring与Hibernate的数据库访问技术,通过将Spring的依赖注入和事务管理与Hibernate的ORM特性相结合,不仅简化了数据持久层的开发,提高了代码的可维护性和可测试性,还极大地提升了系统的性能和响应速度。...
标题“Spring-MF-ORM”暗示我们关注的是Spring框架与对象关系映射(ORM)的结合,特别是关于在Java环境中如何使用Spring来管理数据库操作。ORM是Object-Relational Mapping的缩写,它允许开发者使用面向对象的方式来...
数据访问/集成模块则提供了与数据库交互的支持,包括JDBC、ORM(Object-Relational Mapping)框架如Hibernate或MyBatis等。 总的来说,Spring框架通过IOC和AOP等机制,提供了强大的组件管理和代码解耦能力。而C3P0...
Spring通过其数据访问抽象层,提供了统一的API和事务管理,使得在不同的ORM框架间切换变得容易。 1. Hibernate:Hibernate是Java领域中最受欢迎的ORM框架之一,Spring3提供了对它的深度支持。Spring的...
首先,Spring框架提供了强大的数据访问抽象层,使得开发者可以轻松地与各种数据库交互,包括关系型数据库如MySQL、Oracle,以及非关系型数据库如MongoDB、Cassandra等。Spring Data项目是这一抽象层的核心,它为多种...
数据库访问组件是软件开发中一个至关重要的部分,它允许应用程序与各种类型的数据库进行交互,以存储、检索和处理数据。这些组件通常包含了多种接口、类和工具,为开发者提供了便捷的方式来执行SQL查询、事务管理、...