Spring3.1.2與Hibernate4.1.8整合

jopen 12年前發布 | 82K 次閱讀 Spring3 JEE框架 Hibernate4

整合Spring3.1.2 與 Hibernate 4.1.8

首先準備整合jar:


Spring3.1.2:

org.springframework.aop-3.1.2.RELEASE.jar
org.springframework.asm-3.1.2.RELEASE.jar
org.springframework.aspects-3.1.2.RELEASE.jar
org.springframework.beans-3.1.2.RELEASE.jar
org.springframework.context.support-3.1.2.RELEASE.jar
org.springframework.context-3.1.2.RELEASE.jar
org.springframework.core-3.1.2.RELEASE.jar
org.springframework.expression-3.1.2.RELEASE.jar(使用表達式${})
org.springframework.jdbc-3.1.2.RELEASE.jar
org.springframework.orm-3.1.2.RELEASE.jar
org.springframework.transaction-3.1.2.RELEASE.jar


Hibernate4.1.8:

--------------required下面---------------
antlr-2.7.7.jar
dom4j-1.6.1.jar
hibernate-commons-annotations-4.0.1.Final.jar
hibernate-core-4.1.8.Final.jar
hibernate-jpa-2.0-api-1.0.1.Final.jar
javassist-3.15.0-GA.jar
jboss-logging-3.1.0.GA.jar
jboss-transaction-api_1.1_spec-1.0.0.Final.jar
----------------------------

-----proxool-------
proxool-0.9.1.jar
proxool-cglib.jar

其他依賴包
aopalliance-1.0.jar
aspectjrt-1.7.0.jar
aspectjweaver-1.7.0.jar
commons-logging-1.1.1.jar

--數據庫
mysql-connector-java-5.1.21.jar


整合示例:

UserModel:
    UserModel:

package cn.sh.model;  

public class UserModel {  
    private int id;  
    private String username;  
    private String password;  

    --------getter & setter------  
}  </pre>user.hbm.xml<pre class="brush:xml; toolbar: true; auto-links: false;">    <?xml version="1.0" encoding="UTF-8"?>    
<!DOCTYPE hibernate-mapping PUBLIC    
        "-//Hibernate/Hibernate Mapping DTD 3.0//EN"    
        "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">  
<hibernate-mapping>  
    <class name="cn.sh.model.UserModel" table="user">  
        <id name="id" column="id">  
            <generator class="native" />  
        </id>  
        <property name="username" column="username" />  
        <property name="password" column="password" />  
    </class>  
</hibernate-mapping>  </pre>resources/jdbc.properties:<pre class="brush:java; toolbar: true; auto-links: false;">    proxool.maxConnCount=10  
proxool.minConnCount=5  
proxool.statistics=1m,15m,1h,1d  
proxool.simultaneousBuildThrottle=30  
proxool.trace=false  

jdbc.driverClassName=com.mysql.jdbc.Driver  
jdbc.url=jdbc:mysql://localhost:3306/ssh  
jdbc.username=root  
jdbc.password=admin  </pre>resources/applicationContext-common.xml:<pre class="brush:xml; toolbar: true; auto-links: false;">    <?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">  
            <list>  
                <value>classpath:jdbc.properties</value>  
            </list>  
        </property>  
    </bean>  

     <!-- 數據源 -->  
    <bean id="dataSource" class="org.springframework.jdbc.datasource.LazyConnectionDataSourceProxy">  
        <property name="targetDataSource">  
            <bean class="org.logicalcobwebs.proxool.ProxoolDataSource">  
                <property name="driver" value="${jdbc.driverClassName}" />  
                <property name="driverUrl" value="${jdbc.url}" />  
                <property name="user" value="${jdbc.username}" />  
                <property name="password" value="${jdbc.password}" />  
                <property name="maximumConnectionCount" value="${proxool.maxConnCount}" />  
                <property name="minimumConnectionCount" value="${proxool.minConnCount}" />  
                <property name="statistics" value="${proxool.statistics}" />  
                <property name="simultaneousBuildThrottle" value="${proxool.simultaneousBuildThrottle}" />  
                <property name="trace" value="${proxool.trace}" />  
            </bean>  
        </property>  
    </bean>  

    <!--  -->  
    <bean id="sessionFactory" class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">  
        <property name="dataSource" ref="dataSource" />  
        <property name="mappingResources">  
            <list>  
                <value>cn/sh/model/user.hbm.xml</value>  
            </list>  
        </property>  
        <property name="hibernateProperties">  
            <value>  
                hibernate.dialect=org.hibernate.dialect.HSQLDialect  
                hibernate.show_sql=true  
            </value>  
        </property>  
    </bean>  

    <!-- 聲明式事務 -->  
    <bean id="transactionManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">  
        <property name="sessionFactory" ref="sessionFactory" />  
    </bean>  

    <aop:config>  
        <aop:pointcut id="productServiceMethods" expression="execution(* cn.sh.service..*.*(..))" />  
        <aop:advisor advice-ref="txAdvice" pointcut-ref="productServiceMethods" />  
    </aop:config>  

    <tx:advice id="txAdvice" transaction-manager="transactionManager">  
        <tx:attributes>  
            <tx:method name="increasePrice*" propagation="REQUIRED" />  
            <tx:method name="someOtherBusinessMethod" propagation="REQUIRES_NEW" />  
            <tx:method name="*" propagation="SUPPORTS" read-only="true" />  
        </tx:attributes>  
    </tx:advice>  


</beans>  </pre>整合測試:<pre class="brush:java; toolbar: true; auto-links: false;">    public class SpringHibernateTest {  

    private SessionFactory sessionFactory;  
    private ApplicationContext ctx;  

    @Before  
    public void setUp() {  
        String[] configLocations = new String[] {"classpath:applicationContext-*.xml"};  
        ctx = new ClassPathXmlApplicationContext(configLocations);  
        sessionFactory = ctx.getBean("sessionFactory", SessionFactory.class);  
    }  

    @Test  
    public void testSessionFactory(){  
        System.out.println(sessionFactory);  
        System.out.println(ctx.getBean("dataSource"));  
        Session session = sessionFactory.openSession();   
        UserModel model = new UserModel();    
        model.setUsername("wangwu");  
        model.setPassword("123456");  
        session.save(model);  
    }  
}  </pre>來自:http://blog.csdn.net/cjj3930337/article/details/8217135
 本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!