Spring3+hibernate4框架整合

花了俩天时间复习了一下Spring和jhibernate架构知识,在学习过程中受益颇多。知识用起来才能活起来,长时间不去触碰他就会变得很陌生。

Spring 提供了统一的数据访问架构,可以支持JDBC与hibernate的结合流程,其具体实现流程如下:

1.创建数据表的实体类

2.配置数据表的映射关系

3.配置Hibernate SessionFactory数据源

4.编写测试类查看结果。

 

项目目录结构如下:

基本jar包

hibernater 版本:hibernate-release-4.3.10.Final

Spring 版本:spring-framework-3.2.4.RELEASE

其他依赖jar包:

JDK 版本:jdk 7

数据库版本:mysql 5.5及以上

第一步:在上面的src目录下的 com.sgl.POJO 包下面新建一个实体类,例如 p_User.java,创建与数据表字段名相同的属性,并为属性添加get和set方法。

注意的是,该类必须与数据表一一映射,所以为该类添加注解,用于指定映射的表名。

第二步:在上面的src目录下的 com.sgl.POJO 包下面新建一个p_user.hbm.xml。创建数据表与其实体类的映射关系。

第三步:在Spring的ApplicationContext.xml中配置SessionFactory

在Spring框架中允许ApplicationContext以Bean的形式定义Hibernate的SessionFactory数据源。

<?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: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-3.0.xsd  
                           http://www.springframework.org/schema/tx   
                           http://www.springframework.org/schema/tx/spring-tx-3.0.xsd  
                           http://www.springframework.org/schema/aop   
                           http://www.springframework.org/schema/aop/spring-aop-3.0.xsd">
    <!-- 引入配置文件 -->
    <!-- <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> 
        <property name="locations"> <value>classpath:jdbc.properties</value> </property> 
        </bean> <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}" /> </bean> -->
    <!-- 数据源 jdbc方式配置 -->
    <bean id="DataSource" class="org.apache.commons.dbcp.BasicDataSource"
        destroy-method="close">
        <property name="driverClassName" value="com.mysql.jdbc.Driver" />
        <property name="url" value="jdbc:mysql://localhost:3306/bsoftdb" />
        <property name="username" value="root" />
        <property name="password" value="123" />
    </bean>

    <bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
        <property name="DataSource" ref="DataSource" />
        <property name="mappingResources">
            <list>
                <value>com/sgl/POJO/P_User.hbm.xml</value> 
            </list>
        </property>
        <property name="hibernateProperties">
            <value>
                hibernate.dialect=org.hibernate.dialect.HSQLDialect
                hibernate.show_sql=true
            </value>
        </property>
    </bean>
</beans> 

编写测试类:

 

posted @ 2015-08-25 17:32  爪哇小生  阅读(1041)  评论(0编辑  收藏  举报