`
牛人云小白
  • 浏览: 3183 次
文章分类
社区版块
存档分类
最新评论

spring支持的DAO操作

阅读更多
spring提供访问数据库的有三种方式: HibernateDaoSupport,HibernateTemplate(推荐使用),jdbcTemplate

HibernateTemplate:org.springframework.orm.hibernate3.HibernateTemplate

HibernateDaoSupport:org.springframework.orm.hibernate3.support.HibernateDaoSupport

spring如果想整合hibernate的话,首先就应该获得SessionFactory这个类,然后再通过获得session就可以进行访问数据库了

即spring提供的类HibernateDaoSupport,HibernateTemplate应该是有setSessionFactory,在使用的时候注入一下就可以了

<bean id="sessionFactory" class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
   <property name="dataSource" ref="dataSource"></property>
   <property name="annotatedClasses">
    <list>
     <value>com.zcy.model.User</value>
     <value>com.zcy.model.Log</value>
    </list>
   </property>
   <property name="hibernateProperties">
   <props>
    <prop key="hibernate.dialect">
     org.hibernate.dialect.OracleDialect
    </prop>
    <prop key="hibernate.hbm2ddl.auto">update</prop>
    <prop key="hibernate.show_sql">
     true
    </prop>
   </props>
  </property>
  </bean>

对于HibernateTemplate:

<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
  <property name="sessionFactory" ref="sessionFactory"></property>
</bean>

在程序中直接用就可以了,如下

@Component("u")
public class UserDaoImpl_HibernateTemplate implements UserDao {
private HibernateTemplate  hibernateTemplate;

@Resource
public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {
  this.hibernateTemplate = hibernateTemplate;
}


public void save(User user) {
  hibernateTemplate.save(user);
}

}

对于HibernateDaoSupport:

public final void setSessionFactory(SessionFactory sessionFactory)

public final SessionFactory getSessionFactory()

public final void setHibernateTemplate(HibernateTemplate hibernateTemplate)

public final HibernateTemplate getHibernateTemplate()

从它类里的方法可以知道,在使用的时候只需要将sessionFactory注入给HibernateDaoSupport,然后就可以通过getHibernateTemplate

来获得HibernateTemplate,这样就可以使用HibernateTemplate了,就和上面使用HibernateTemplate的一样的

(显然这有点绕了一点弯,个人感觉还是直接使用HibernateTemplate就可以了,不过根据个人喜好或项目的需求而定)

下面是实现设计的方法:

service:

public class UserService {
private UserDao userDao;

public void setUserDao(UserDao userDao) {
  this.userDao = userDao;
}
  
public void add(User user){
    userDao.save(user);
}

dao:

public class UserDaoImpl extends HibernateDaoSupport implements UserDao {
public void save(User user) {
    this.getHibernateTemplate().save(user);
}

}

bean.xml:

<bean id="userService" class="com.zcy.service.UserService">
  <property name="userDao" ref="userDao"></property>
</bean>


<bean id="userDao" class="com.zcy.dao.impl.UserDaoImpl">
  <property name="sessionFactory" ref="sessionFactory"></property>
</bean>

这里的sessionFacotry注入不是给类UserDaoImpl 的,而是给继承HibernateDaoSupport类的sessionFactory,使用HibernateDaoSupport好处就是我们不再需要关心关闭、

是否连接成功等问题(在使用spring封装的这些类,即HibernateDaoSupport,HibernateTemplate,jdbcTemplate,都不需要关心是否关闭,是否连接的问题,因为spring已这些操作封装给注入好了),

这样用起来很方便。但是这个不好就是java只支持单继承,所以唯一的继承给了HibernateDaoSupport有点可惜。

另外注意的是因为HibernateDaoSupport已经有setSessionFactory(SessionFactory sessionFactory)这个方法了,所以在UserDaoImpl 的类里就不需要写了,

并且HibernateDaoSupport的setSessionFactory的方法时final的,所以重写还会报错的。



对于jdbcTemplate以后再做整理吧





hibernateTemplate的常用方法:
?void delete(Object entity):删除指定持久化实例

?deleteAll(Collection entities):删除集合内全部持久化类实例

?find(String queryString):根据HQL查询字符串来返回实例集合

?findByNamedQuery(String queryName):根据命名查询返回实例集合

?get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例

?save(Object entity):保存新的实例

?saveOrUpdate(Object entity):根据实例状态,选择保存或者更新

?update(Object entity):更新实例的状态,要求entity是持久状态

?setMaxResults(int maxResults):设置分页的大小



HibernateDaoSupport:
Spring为Hibernate的DAO提供工具类:HibernateDaoASupport。该类主要提供如下两个方法,方便DAO的实现:
1、public final HibernateTemplate getHibernateTemplate()
2、public final void setSessionFactory(SessionFactory sessionFactory)
其中setSessionFactory方法用来接收Spring的ApplicationContext的依赖注入,可接收配置在Spring的SessionFactory实例,getHibernateTemplate方法则用来更具获得的SessionFactory产生Session,最后生成HibernateTeplate来完成数据库访问。
HibernateTemplate用于持久层的访问,该模板无需打开session及关闭Session。它只要获得SessionFactory的引用,就可以打开Session,并在持久化访问结束后关闭Session,程序开发只需要完成持久曾逻辑,通用的CRUD操作由HibernateTemplate完成.
其实Spring+hibernate访问数据库有以下几种方法:
1、注入SessionFactory

在spring配置文件中,对Dao注入sessionFactory.比较简单。
如:
<beanid="UserInfoDao"class="com.hr2job.dao.impl.UserInfoDaoImpl">
         <propertyname="sessionFactory"ref="sessionFactory"></property>
</bean>
这里的sessionFacotry注入不是给类的,而是给继承HibernateDaoSupport类的sessionFactory,在上面源码中可以看到。以前写SSH程序的时候就是用这个的,因为是不知道,这个好处就是我们不再需要关心关闭、是否连接成功等问题。主要是很方便。但是这个不好就是java只支持单继承,所以唯一的继承给了HibernateDaoSupport有点可惜。而且也没有必要这样做。
2、注入HibernateTemplate

这种方法本质上跟上面的sessionFacotry一样,只不过进行了一层包装,好处就是Dao中的类就不用再继承那个HibernateDaoSuport了,不过要先配置好HibernateTemplate:
<bean id="hibernateTemplate" class="org.springframework.orm.hibernate3.HibernateTemplate">
        <property name="sessionFactory">
            <ref bean="sessionFactory"/>
        </property>
   </bean>
非常的方便,我现在就在用这个了。其实并没有改多少,就是曾经的sessionFactroy改成了hibernatemplate。
3、注入jdbcTemplate

这种方法适合那些不喜欢hibernate的save,delete等方法,喜欢自己写的N人吧。有时候jdbcTemplate查询的效率会很高。这可能是跟jdbc有关吧。
配置如下:
<bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
   <property name="dataSource">
    <ref bean="dataSource" />
   </property>
</bean>
在类中set方法jdbctemplate方法就可以了,spring中的配置跟sessionFactory基本一样。
总的感觉还是喜欢HibernateTemplate,原因就是好用,不需要写太多的sql语句,不需要
类去继承,只要提供一个set方法,再注入一下很方便。
分享到:
评论

相关推荐

    Spring支持DAO需要的jar包

    Spring支持DAO的主要目的是为了实现数据访问的解耦和抽象,使得业务逻辑与数据库操作分离,提高代码的可测试性和可维护性。Spring提供了一套完整的DAO支持,包括事务管理、异常处理、数据源管理等,使得开发者可以...

    spring几种Dao支持配置

    Spring提供了多种方式来支持DAO的配置,使得开发人员可以灵活地选择最适合项目需求的数据访问策略。以下将详细阐述Spring对DAO支持的几种配置方式: 1. **JDBC DAO支持:** Spring通过`JdbcTemplate`和`...

    使用Spring实现DAO模式

    Spring框架提供了丰富的特性来支持DAO模式的实现,包括但不限于: - **事务管理**:Spring的事务管理机制允许开发者在不侵入业务代码的情况下,轻松地管理事务边界。通过配置,可以自动开启和提交事务,或者在异常...

    Spring的DAO

    Spring支持多种数据源配置方式,包括从JNDI查找数据源和直接在XML配置文件中定义。以下是一个使用Apache Commons DBCP数据源的例子: ```xml ${jdbc.driverClassName}" /&gt; ${jdbc.url}" /&gt; ${jdbc.username}" /...

    dao.rar_spring-dao

    Spring框架提供了对DAO的支持,通过依赖注入(DI)和面向切面编程(AOP)简化了数据访问层的实现。 描述中提到的"一个综合系统的完整代码三struts.hibernate3.0,spring的结构"表明这是一个包含三层架构(MVC)的...

    spring 对dao 的操作

    Spring 提供了两种主要的方式来实现DAO操作: 1. **JDBC模板**:Spring JDBC模块包含了一个名为`JdbcTemplate`的类,它简化了JDBC的使用,避免了繁琐的数据库连接管理和异常处理。开发者只需要编写SQL查询,`...

    Spring DAO

    Spring框架提供了一套强大的数据访问抽象层——DAO(Data Access Object)支持,使得开发者能够在不关心具体数据库技术细节的情况下完成数据访问任务。这一机制极大地简化了开发过程,降低了代码的耦合度,并提高了...

    spring-jdbc-dao

    1. DataSource:数据源是连接数据库的关键,Spring支持多种DataSource实现,如Apache Commons DBCP、C3P0等,它们负责管理数据库连接池。 2. JdbcTemplate:它是Spring JDBC的核心,提供了执行SQL语句和处理结果集的...

    Struts2+hibernate+spring整合泛型DAO

    在Struts2+Hibernate+Spring的集成中,泛型DAO扮演着重要的角色,它使得DAO层对所有实体类的操作变得统一和规范。 首先,让我们详细了解一下Struts2。Struts2是基于拦截器的MVC框架,它提供了强大的动作映射、结果...

    spring boot服务器dao层实例化.rar_dao实例化_idea 实例ID_spring boot_spring b

    在Spring框架中,DAO接口通常用于定义数据访问的方法,而其对应的实现类则负责具体的数据库操作。Spring Boot通过依赖注入(Dependency Injection, DI)来管理这些DAO对象,使得它们可以在需要时自动被创建和初始化...

    SpringDao模式实例

    在Spring框架中,DAO(Data Access Object)模式是将业务逻辑与数据操作解耦,使得代码更易于测试和维护。 Spring DAO模式的核心组件包括以下几个部分: 1. **JdbcTemplate**: Spring提供的一个核心模板类,用于...

    Spring + Hibernate DAO 代码上传

    - **Spring JDBC和ORM支持**:Spring提供了JDBC抽象层,简化数据库操作,同时支持多种ORM框架,包括Hibernate。 2. **Hibernate ORM框架**: - Hibernate是一个流行的Java持久化框架,它简化了与关系数据库的交互...

    利用JUnit和Spring-test对SpringJDBC组件DAO层测试

    在Java开发中,Spring框架是广泛使用的,其中Spring JDBC组件为数据库操作提供了强大的支持。而单元测试是确保代码质量、预防缺陷的重要手段。本话题将深入讲解如何利用JUnit和Spring-test这两个工具对SpringJDBC...

    使用Spring的NamedParameterJdbcTemplate完成DAO操作

    通过以上步骤,我们可以看到`NamedParameterJdbcTemplate`如何简化了DAO操作,使得SQL语句更加直观,同时避免了SQL注入的风险。这个工具是Spring框架中用于数据库操作的一个强大而灵活的选择,尤其适合那些重视代码...

    Hibernate泛型DAO(结合spring模板支持)

    至于`Dao经典泛型.doc`文件,可能是更深入的关于Hibernate泛型DAO的文档,可能包含了如何配置Spring、如何处理复杂查询以及如何优化泛型DAO的更多细节。阅读这份文档将进一步提升你对泛型DAO的理解和应用能力。 ...

    经典spring关于关于dao模式的开发案例

    在Spring框架中,DAO(Data Access Object)模式是一种常见的设计模式,用于封装对数据库的访问操作,以此来解耦业务逻辑层与数据访问层。这个经典的Spring DAO模式开发案例提供了深入理解Spring如何处理数据访问的...

    spring和mybatis整合(原始dao方式实现

    - 在Spring中,原始DAO方式指的是不使用MyBatis的Mapper接口,而是直接通过SqlSession进行数据库操作。这需要我们在DAO实现类中注入SqlSessionFactory,然后创建SqlSession实例,调用其`openSession()`、`selectOne...

    spring jar 包详解

    此外,`spring-dao.jar`还包含了事务管理功能,使开发者能够在复杂的业务逻辑中进行一致性的数据操作。 #### spring-jdbc.jar `spring-jdbc.jar`扩展了JDBC的使用,提供了错误转换、批量更新、数据库元数据获取等...

    mybatis_spring(原始dao开发方法的整合)

    整合完成后,我们就可以在Spring的Service层或者DAO层注入所需的Mapper接口,直接调用其方法进行数据库操作,Spring会自动处理SqlSession的生命周期和事务管理。 总结来说,MyBatis与Spring的整合是通过Spring的IoC...

Global site tag (gtag.js) - Google Analytics