您的位置:首页 > 编程语言 > Java开发

Spring 整合 Hibernate

2015-07-24 14:35 295 查看
PS:前段时间一直都在学校,要么上课,要么做学期最后的课程设计,一直无暇整理所学。前些天刚来公司实习,感觉好像对于三大框架的应用并没有很多,只有Spring,也是为了对过去的总结,也是为了怕自己后来再用的时候又要各处找资料。及时的把框架整合进行整理,迎接新的工作~~

1.Spring 整合 Hibernate 整合什么?
1)有 IOC 容器来管理 Hibernate 的 SessionFactory;
2)让 Hibernate 使用 Spring 的声明式事务。
[事务:一系列的动作,它们被当做一个单独的工作单元,这些动作要么全部完成,要么全部不起作用]

2.整合步骤
1)加入 hibernate : 编写持久化类对应的 .hbm.xml
2)加入 Spring
1>加入jar包
2>加入Spring的配置文件,即整合的过程
[命名空间]




3)整合(spring2.0)
1.配置数据源





<bean id="dataSource"
class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName"
value="oracle.jdbc.driver.OracleDriver">
</property>
<property name="url"
value="jdbc:oracle:thin:@localhost:1521:inspur">
</property>
<property name="username" value="scott"></property>
<property name="password" value="tiger"></property>
</bean>
2.配置 Hibernate 的 SessionFactory 实例



(通过 Spring 提供的 LocalSessionFactoryBean 进行配置)
<bean id="sessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<!-- 配置数据源属性 -->
<property name="dataSource" ref="dataSource"></property>
<!-- 用来列出全部映射文件(位置及名称) -->
<property name="mappingResources">
<!-- *.hbm.xml -->
<list>
<value>com/inspur/entity/Account.hbm.xml</value>
<value>com/inspur/entity/Book.hbm.xml</value>
</list>
</property>
<!-- 定义Hibernate的SessionFactory属性 -->
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.Oracle10gDialect
</prop>
<prop key="hibernate.hbm2ddl.auto">update</prop>
<prop key="hibernate.show_sql">true</prop>
</props>
</property>
</bean>
3.配置Spring的声明式事务



<!-- 配置Hibernate的局部事务管理器 -->
<bean id="transactionManager"
class="org.springframework.orm.hibernate3.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory"></property>
</bean>
<!-- 配置事务的通知(需要引入 tx 命名空间) -->
<tx:advice id="transaction"
transaction-manager="transactionManager">
<!-- 为每类方法配置各自的事务 -->
<tx:attributes>
<tx:method name="get*" read-only="true" />
<tx:method name="*" propagation="REQUIRED"
isolation="READ_COMMITTED" />
</tx:attributes>
</tx:advice>
<!-- 配置事务切点,并把切点和事务属性(通知)关联起来(需要引入 aop 命名空间)service实现类做切点 -->
<aop:config>
<aop:pointcut id="txPointcut"
expression="execution(* com.inspur.service.impl.*.*(..))" />
<aop:advisor advice-ref="transaction" pointcut-ref="txPointcut" />
</aop:config>
以上是配置文件,虽然大多时候可以copy , paste 来完成,但是自己还是经常手写来配置,加深印象。下面通过代码对比较重要的地方进行解释。[对 hibernateTemplate 以及 SessionFactory 的区别进行解释]

package com.inspur.dao.impl;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import com.inspur.dao.BookDao;
public class BookDaoImpl implements BookDao {
// Hibernate 模板类 但不推荐如此使用
/**
* 原因:HibernateTemplate 是 Spring 中的类,不支持 Spring4 因为这样会导致 Dao 和 Spring 的 API
* 进行耦合,导致可移植性变差 当 Hibernate 和 Spring 整合,可以如此使用。只是可移植性变差
*/
/*
* private HibernateTemplate hibernateTemplate;
*
* public HibernateTemplate getHibernateTemplate() { return
* hibernateTemplate; }
*
* public void setHibernateTemplate(HibernateTemplate hibernateTemplate) {
* this.hibernateTemplate = hibernateTemplate; }
*/
// SessionFactory Hibernate 原生 API
public SessionFactory sessionFactory;
// 获取跟当前线程绑定的Session*****
public Session getSession() {
return sessionFactory.getCurrentSession();
}
// SessionFactory 的 get、set 方法
public SessionFactory getSessionFactory() {
return sessionFactory;
}
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
/**
* 根据书号获取书的单价
*/
public int findBookPriceByIsbn(String isbn) {
String hql = "select b.price from Book as b where b.isbn = ?";
Query query = getSession().createQuery(hql).setString(0, isbn);
return (Integer) query.uniqueResult();
}
/**
* 更新书的库存,使书号对应的库存 -1
*/
public void updateBookStock(String isbn) {
// 验证书的库存是否充足
String hql2 = "select b.stock from Book as b where b.isbn = ?";
int stock = (Integer) getSession().createQuery(hql2).setString(0, isbn)
.uniqueResult();
if (stock == 0) {
System.out.println("库存不足!");
}
String hql = "update Book as b set b.stock = b.stock - 1 where b.isbn = ?";
getSession().createQuery(hql).setString(0, isbn).executeUpdate();
}
/**
* 更新用户的账户余额:使username的balance - price
*/
public void updateUserAccount(String username, int price) {
// 验证余额是否足够
String hql2 = "select a.balance from Account as a where a.username = ?";
int balance = (Integer) getSession().createQuery(hql2).setInteger(0,
price).uniqueResult();
if (balance < price) {
System.out.println("余额不足!");
}
String hql = "update Account as a set a.balance = a.balance - ? where a.username = ?";
getSession().createQuery(hql).setInteger(0, price).setString(1,
username).executeUpdate();
}
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: