Spring与JPA(Hibernate)集成

第一步:拷贝JAR包(包括Spring,Hibernate,数据库驱动JAR包);

第二步:于Src文件夹下新建一文件夹命名为:META-INF,其中放一文件:persistence.xml,此文件用于配置数据库链接等信息。

 

  1. <?xml version="1.0"?>  
  2. <persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  3. xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0">  
  4. <!-- file:///D:/hibernate/hibernate-entitymanager-3.3.2.CR1/resources/org/hibernate/ejb/persistence_1_0.xsd -->  
  5.   <persistence-unit name="itcast" transaction-type="RESOURCE_LOCAL">  
  6.     <provider>org.hibernate.ejb.HibernatePersistence</provider>  
  7.     <properties>  
  8.          <property name="hibernate.dialect" value="org.hibernate.dialect.MySQLDialect"/>  
  9.          <property name="hibernate.connection.driver_class" value="org.gjt.mm.mysql.Driver"/>  
  10.          <property name="hibernate.connection.username" value="root"/>  
  11.          <property name="hibernate.connection.password" value="mysql"/>  
  12.          <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/itcast?useUnicode=true&characterEncoding=UTF-8"/>  
  13.          <property name="hibernate.max_fetch_depth" value="3"/>  
  14.          <property name="hibernate.hbm2ddl.auto" value="update"/>  
  15.          <property name="hibernate.jdbc.fetch_size" value="18"/>  
  16.          <property name="hibernate.jdbc.batch_size" value="10"/>  
  17.          <property name="hibernate.show_sql" value="true"/>  
  18.          <property name="hibernate.format_sql" value="false"/>   
  19.       </properties>  
  20.   </persistence-unit>  
  21. </persistence>  

第三步:将beans.xml(或applicationContext.xml)放于Src下,并进行配置。

  1. <?xml version="1.0" encoding="UTF-8"?>  
  2.   
  3. <beans xmlns="http://www.springframework.org/schema/beans"  
  4.         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  5.         xmlns:context="http://www.springframework.org/schema/context"  
  6.         xmlns:aop="http://www.springframework.org/schema/aop"  
  7.         xmlns:tx="http://www.springframework.org/schema/tx"  
  8.         xsi:schemaLocation="  
  9.             http://www.springframework.org/schema/beans  
  10.             http://www.springframework.org/schema/beans/spring-beans-2.5.xsd  
  11.             http://www.springframework.org/schema/context   
  12.             http://www.springframework.org/schema/context/spring-context-2.5.xsd  
  13.             http://www.springframework.org/schema/aop   
  14.             http://www.springframework.org/schema/aop/spring-aop-2.5.xsd  
  15.             http://www.springframework.org/schema/tx   
  16.             http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">  
  17.     
  18.  <context:annotation-config/>  
  19.   
  20.   <!--实体bean所在的基础包的包名为:cn.yang-->  
  21.     <context:component-scan base-package="cn.yang"/>  
  22. <!-- 使用数据源和指定persistence.xml位置的方式创建entityManagerFactory,如果使用的不是hibernate JPA实现,  
  23.     需要在tomcat作一些特殊配置.具体参考手册  
  24.     注意:使用该方式需要把persistence.xml中的hibernate.connection.driver_class,hibernate.connection.username,hibernate.connection.password,hibernate.connection.url配置删除  
  25. -->  
  26. <!--指定jdbc.properties的位置  
  27.     <context:property-placeholder location="classpath:jdbc.properties"/>  
  28.      -->  
  29. <!-- 此配置与上面的配置同效,两都选一即可。  
  30.     <bean class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">  
  31.         <property name="locations">  
  32.             <list>  
  33.             <value>classpath:jdbc.properties</value>  
  34.             </list>  
  35.         </property>  
  36.     </bean>  
  37.  -->  
  38.   <!--配置数据源,使用到了jdbc.properties。  
  39.     <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource" destroy-method="close">  
  40.         <property name="driverClassName" value="${jdbc.driverClassName}" />  
  41.         <property name="url" value="${jdbc.url}" />  
  42.         <property name="username" value="${jdbc.username}" />  
  43.         <property name="password" value="${jdbc.password}" />  
  44.     </bean>  
  45.   -->  
  46.  <!--JPA中管理实体Bean。  
  47.   <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">  
  48.    <property name="dataSource" ref="dataSource" />  
  49.    <property name="persistenceXmlLocation" value="classpath:META-INF/persistence.xml"/>  
  50.  <property name="loadTimeWeaver">  
  51.      <bean  
  52.  class="org.springframework.instrument.classloading.InstrumentationLoadTimeWeaver" />  
  53.  </property>  
  54.   </bean>  
  55.    -->  
  56.     <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalEntityManagerFactoryBean">  
  57.        <property name="persistenceUnitName" value="itcast"/>  
  58.    </bean>  
  59. <!--事务管理Bean-->  
  60.   <bean id="myTxManager" class="org.springframework.orm.jpa.JpaTransactionManager">  
  61.    <property name="entityManagerFactory" ref="entityManagerFactory"/>  
  62.   </bean>  
  63. <!--说明事务的配置使用的注解方式-->  
  64.    <tx:annotation-driven transaction-manager="myTxManager"/>  
  65. </beans>  

第四步:进行领域建模,写出实体Bean。

第五步:新建一个单元测试类,其中的一个方法写成如下代码:

  1. @Test  
  2. public void test(){  
  3. //启动Spring容器   
  4. ApplicationContext beans=new ClassPathXmlApplicationContext("beans.xml");  
  5. }  

以上代码的作用就是找到类路径下的beans.xml文件,启动Spring容器,在起动Spring容器过程中,需要创建名为entityManagerFactory的Bean,就是在创建此bean的过程中将实体bean生成对应数据库中的表。

若生成表成功,则表示Spring与JPA集成成功。

注:

(1)若想在单元测试中直接操作JPA,则需写如下代码:

  1. //直接操作JPA   
  2. EntityManagerFactory    factory=Persistence.createEntityManagerFactory("itcast");  
  3. //itcast为persistence.xml中定义的实例化单元名。  
  4. EntityManager em=factory.createEntityManager();  
  5. em.getTransaction().begin();  
  6. em.persist(new ProductType());  
  7. em.getTransaction().commit();  
  8. em.close();  
  9. factory.close();  

(2) 在业务bean中使用EntityManager的方法:

  1. @PersistenceContext  
  2. protected EntityManager em;  

至此,Spring与JPA集成完毕。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值