Spring集成hibernate的目的:
将所有的Dao对象集中由spring管理。
Spring对Hibernate进一步进行了封装,更加的便于使用。
使用spring的声明式事务,开发者可以不用关注事务。
jdbc:mysql://127.0.0.1:3306/hibernate_test
sessionFactory需要由spring来创建,所以要在容器中声明。
hibernate.dialect=org.hibernate.dialect.MySQLDialecthibernate.show_sql=true
com/demo/pojo/StudentInfor.hbm.xml
HibernateDaoSupport 包含HibernateTemplate 模板类,spring 对Hibernate再一次的封装, 使得代码可以更加简洁。BaseDao继承此类型,可以使用HibernateTemplate进行数据库操作。
同时,该模板类依赖sessionFactory, sessionFactory会注入到HibernateDaoSupport里。所以在配置BaseDao时候,需要配置此属性:
public class BaseDaoImpl extends HibernateDaoSupport implements IBaseDao {Class entityClass;public BaseDaoImpl() {// 是得到这个类的得到泛型父类Type genType = getClass().getGenericSuperclass();//返回表示此类型实际类型参数的Type对象的数组,对应类型的Class//可能有多个,取第0个。Type[] params = ((ParameterizedType) genType).getActualTypeArguments();entityClass = (Class) params[0];}
}
@Override
public void save(Object entity) {this.getHibernateTemplate().save(entity);
}
@Override
public void saveOrUpdate(Object entity) {this.getHibernateTemplate().saveOrUpdate(entity);
}
@Override
public T get(Class entityClass, Serializable id) {return this.getHibernateTemplate().get(entityClass, id);
}
@Override
public void update(Object entity) {this.getHibernateTemplate().update(entity);
}
BaseDao实现翻页:
public List findPageObjects(final String hql, final int pageStart, final int pageSize ,final Object... conditions) {List list = this.getHibernateTemplate().executeFind(new HibernateCallback() {@Overridepublic Object doInHibernate(Session session) throws HibernateException, SQLException {Query query = session.createQuery(hql);for(int i=0;i
public int updateObjects(final String hql, final Object... conditions) {int count = this.getHibernateTemplate().execute(new HibernateCallback() {@Overridepublic Object doInHibernate(Session session) throws HibernateException, SQLException {try{Query query = session.createQuery(hql);for(int i=0;i
注意,dao的配置的parent 属性要设置成baseDao。
例子: Db.properties
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/hibernate_test
jdbc.username=root
jdbc.password=root
属性文件通过context:property-placeholder导入后,在数据源配置处即可使用。
例子:
在配置比较多时候,可以将配置文件进行分拆,方便管理。分拆的文件可以使用import标签引入进来:
例子:
public class BaseServiceImpl implements IBaseService {private BaseDao baseDao;public BaseDao getBaseDao() {return baseDao;}public void setBaseDao(BaseDao baseDao) {this.baseDao = baseDao;}@Overridepublic Serializable add(T entity) {return baseDao.save(entity);}@Overridepublic T get(Integer id) {return baseDao.get(id);}@Overridepublic T load(Integer id) {return baseDao.load(id);}@Overridepublic List loadAll() {return baseDao.loadAll();}@Overridepublic void remove(int id) {baseDao.remove(id);}@Overridepublic void update(T entity) {baseDao.update(entity);}
}
声明式事务: 即在配置文件里,配置哪些方法是需要事务的。这些方法的事务的启动和提交,都交给 Spring 来处理。
事务通常配置在服务层,原因是:
业务操作可能是包含相同dao的几个操作的。
业务操作可能是包含不同的dao的几个操作的。
业务操作可能包含不同数据库的dao几个操作的。
以上几种情况,要求事务应该放在服务层。
}
事务管理器需要注入sessionFactory。
Read-only 属性说明:
该属性设置事务是否只读,默认值为false。
如果只是读取数据但不修改数据,可以设置read-only为true,对hibernate 可以有更好的优化。
通常对于查询方法,如get*、load、find*等方法,会设置read-only=true
如果出现异常,事务是会自动回滚的。但是这个异常,必须是RuntimeException。
可以在服务bean中调用super.setBaseDao()将具体类型的Dao实例注入进去。
比如:
public void setUserInforDao(IUserInfor userInforDao) {super.setBaseDao((BaseDaoImpl) userInforDao);this.userInforDao = userInforDao;
}
3. SSH集成
1. 步骤1: 配置struts
2. 步骤2: 配置spring
3. 步骤3: 配置Hibernate
上一篇:创业新者必看 创业者必看 创业人士必看视频 青年创业者必看
下一篇:描述性统计