使用Hibernate 和 Spring 实现一个事务持久层

转载 2005年03月21日 19:34:00
 

1.首先实现一个接口.

============================================================

package com.cqtele.tnbos;
import java.util.*;
public interface IUserDao {
 public void insertUser(userInfo user);
 public List findUser(String sql);
}

==============================================================

2. 实现这个接口.

  这里使用 Spring的 AOP-driven HibernateTemplate 简化 Hibernate 会话的处理.

================================================================
package com.cqtele.tnbos;
import java.util.*;

import net.sf.hibernate.*;
import net.sf.hibernate.cfg.*;
import java.io.Serializable;
import org.springframework.orm.hibernate.*;//.HibernateCallback;
import org.springframework.orm.hibernate.support.HibernateDaoSupport;

public class userDAO extends HibernateDaoSupport implements IUserDao
{
 //public List name=null;
 //Session session;
 private List list=null;
 public void insertUser(userInfo user)
 {
   getHibernateTemplate().saveOrUpdate(user);
 }
 public List findUser(String sql)
 {
  return getHibernateTemplate().find(sql); 
 }
}

=================================================================

3.声明式管理事务.

  bean.xml

==========================================================================

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE beans PUBLIC "-//SPRING/DTD BEAN/EN" "http://www.springframework.org/dtd/spring-beans.dtd">

<beans>
 <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource"
  destroy-method="close">
  <property name="driverClassName">
   <value>com.mysql.jdbc.Driver</value>
  </property>
  <property name="url">
   <value>jdbc:mysql://127.0.0.1:3306/opertselect?useUnicode=true&amp;characterEncoding=GBK</value>
  </property>
   <property name="username">
   <value>root</value>
  </property>
   <property name="password">
   <value></value>
  </property>
 </bean>
 
 <bean id="sessionFactory" class="org.springframework.orm.hibernate.LocalSessionFactoryBean">
  <property name="dataSource">
   <ref local="dataSource" />
  </property>
  <property name="mappingResources">
   <list>
    <value>userInfo.hbm.xml</value>
    <!--value>Fruits.hbm.xml</value-->
   </list>
  </property>
  <property name="hibernateProperties">
   <props>
    <prop key="hibernate.dialect">
     net.sf.hibernate.dialect.MySQLDialect
    </prop>
    <prop key="hibernate.show_sql">true</prop>
   </props>
  </property>
 </bean>
  
 <bean id="transactionManager" class="org.springframework.orm.hibernate.HibernateTransactionManager">
  <property name="sessionFactory">
   <ref local="sessionFactory" />
  </property>
 </bean>
 <bean id="userDAO" class="com.cqtele.tnbos.userDAO">
  <property name="sessionFactory">
   <ref local="sessionFactory" />
  </property>
 </bean>
 <bean id="DAOProxy" class="org.springframework.transaction.interceptor.TransactionProxyFactoryBean">
  <property name="transactionManager">
   <ref bean="transactionManager" />
  </property>
  <property name="target">
   <ref local="userDAO" />
  </property>
  <property name="transactionAttributes">
   <props>
    <prop key="insert*">PROPAGATION_REQUIRED</prop>
    <prop key="get*">PROPAGATION_REQUIRED,readOnly</prop>
   </props>
  </property>
 </bean>
</beans>
==============================================================================

4.使用.(这是关于一个购物车的例子.)
==============================================================================

package com.cqtele.tnbos;

import java.util.*;
import java.io.*;
import org.springframework.beans.factory.BeanFactory;
import org.springframework.beans.factory.xml.XmlBeanFactory;
import org.aopalliance.aop.Advice;

public class login{
 private List list=null;
 private String sql="from userInfo";
 
 public List getAllMessageList()
 {
  try{
   InputStream is = new FileInputStream("bean.xml");
   XmlBeanFactory factory = new XmlBeanFactory(is);
   IUserDao user = (IUserDao)factory.getBean("DAOProxy");
   list = user.findUser(sql);
  }catch(IOException ioe)
  {
   System.out.println("getAllMessageList Ocurr Error!! Message: "+ioe.getMessage());
  }
  return list;
 }
}

======================================================================

5.总结

======================================================================

Hibernate 是一种先进的 OR 映射工具,而 Spring 是一个 AOP 框架和 IOC 容器。这两种技术的综合使用,使得开发人员可以编写媲美数据库厂商的代码,它可以在 J2EE 容器中运行,也可以单独运行.

相关文章推荐

不明觉厉的spring(4)---spring对持久层(jdbc,hibernate)以及事务的支持

Spring对持久层的支持 ① JDBC,② O/R Mapping(Hibernate,TopLink等) Spring对持久层支持采用的策略:   1、Spring对持久层“不发明重复的轮子”,即...
  • Senssic
  • Senssic
  • 2013年10月15日 23:45
  • 2803

用Hibernate和Spring开发持久层

  • 2007年06月25日 12:40
  • 325KB
  • 下载

用 Hibernate 和 Spring 开发持久层

  • 2008年04月02日 12:51
  • 269KB
  • 下载

Spring+Hibernate DAO 持久层开发, Spring 用 Hibernate 访问数据库的三种方法.推荐使用回调

DAO开发 注: (1)以下两者都需在Spring XML配置文件中,注册Bean(实现类)来依赖注入SessionFactory.  (2.1)Spring 中进行事务管理的通常方式是利用...

Spring总结4—对持久层的支持(附:事务管理)

Spring对持久层采用的策略 没有重新实现新的持久层,只是对现有持久层方案进行封装,更利于使用 采用DAO模式 提供了大量的模板类来简化编程(HibernateTemplate、JdbcTempl...

spring mvc 使用拦截器interceptor和自定义Log类实现持久层记录日志

首先spring记录日志我所知道的有两种,一种是通过AOP,另一种是通过拦截器interceptor,我这次选择的是拦截器interceptor: 1.spring-mvc.xml文件中配置拦截器,...

Spring持久层(三) Hibernate

1 先定义配置文件hibernate-context.xml
  • arkblue
  • arkblue
  • 2011年03月08日 17:13
  • 714

Spring笔记整理——持久层的支持(jdbc,hibernate)

Spring强大的基于 JavaBeans 的采用控制反转(Inversion of Control,IoC)原则的配置管理,使得应用程序的组件更加快捷简易。 是一个可用于从 applet 到 ...

从一个简单的WEB项目入手来简单地了解一下什么是Spring之持久层(Dao)

我们从几乎所有的项目都会有的登录模块来入手学习一下Spring的基本概念。关于登录的具体逻辑我这里就不多加赘述。从MVC的思想上我们可以演化出大概3个分层模块:展现层,业务层(Service),持久层...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:使用Hibernate 和 Spring 实现一个事务持久层
举报原因:
原因补充:

(最多只允许输入30个字)