getHibernateTemplate()
spring 中获得由spring所配置的hibernate的操作对象,然后利用此对象进行,保存,修改和删除等操作,此方法是在配置了spring以后,hibernate由spring接管,不直接使用hibernate的session了
HibernateTemplate提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring 2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。下面是HibernateTemplate的常用方法简介:
q void delete(Object entity):删除指定持久化实例
q deleteAll(Collection entities):删除集合内全部持久化类实例
q find(String queryString):根据HQL查询字符串来返回实例集合
q findByNamedQuery(String queryName):根据命名查询返回实例集合
q get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例
q save(Object entity):保存新的实例
q saveOrUpdate(Object entity):根据实例状态,选择保存或者更新
q update(Object entity):更新实例的状态,要求entity是持久状态
q setMaxResults(int maxResults):设置分页的大小
getHibernateTemplate已经封装好了一些基本的方法,可以直接去用,也就是template嘛,
而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行
谈不上什么优点缺点,类似添加删除更新这样的可以直接用getHibernateTemplate而大部分带条件查询的就需要用getSession自己写了
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
主流技术到底就是主流技术,效率就不一般。
Hibernate封装了对数据库的例行操作,比单纯的jdbc的DAO,开发效率要高很多了。而Springframework对Hibernate的操作又进行了进一步的包装,又将开发效率提升不少。下面的例子是Spring自己给的petclinic的样本程序。
原来b/s架构的大量数据库操作可以这么轻松搞定。
hibernamte中基础持久化类BaseDao及实现BaseDaoImpl
以下是实现类,我感觉还行基本的增删改查都有,拿出来分享下:
spring 中获得由spring所配置的hibernate的操作对象,然后利用此对象进行,保存,修改和删除等操作,此方法是在配置了spring以后,hibernate由spring接管,不直接使用hibernate的session了
HibernateTemplate提供非常多的常用方法来完成基本的操作,比如通常的增加、删除、修改、查询等操作,Spring 2.0更增加对命名SQL查询的支持,也增加对分页的支持。大部分情况下,使用Hibernate的常规用法,就可完成大多数DAO对象的CRUD操作。下面是HibernateTemplate的常用方法简介:
q void delete(Object entity):删除指定持久化实例
q deleteAll(Collection entities):删除集合内全部持久化类实例
q find(String queryString):根据HQL查询字符串来返回实例集合
q findByNamedQuery(String queryName):根据命名查询返回实例集合
q get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例
q save(Object entity):保存新的实例
q saveOrUpdate(Object entity):根据实例状态,选择保存或者更新
q update(Object entity):更新实例的状态,要求entity是持久状态
q setMaxResults(int maxResults):设置分页的大小
getHibernateTemplate已经封装好了一些基本的方法,可以直接去用,也就是template嘛,
而getSession只是获取一个数据工厂的session,然后大部分方法都需要自己写,加hql语句,然后用query方法执行
谈不上什么优点缺点,类似添加删除更新这样的可以直接用getHibernateTemplate而大部分带条件查询的就需要用getSession自己写了
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&
主流技术到底就是主流技术,效率就不一般。
Hibernate封装了对数据库的例行操作,比单纯的jdbc的DAO,开发效率要高很多了。而Springframework对Hibernate的操作又进行了进一步的包装,又将开发效率提升不少。下面的例子是Spring自己给的petclinic的样本程序。
原来b/s架构的大量数据库操作可以这么轻松搞定。
hibernamte中基础持久化类BaseDao及实现BaseDaoImpl
package com.ssh.neb.dao;
import java.io.Serializable;
import java.util.Collection;
import java.util.List;
public interface BaseDao {
public Object find(String queryString,Object[] values);
public List findList(String queryString, Object[] values);
public List getAllObject(Class clazz);
public Object getObject(Class clazz, Serializable id);
public void saveObject(Object o);
public void removeObject(Class clazz, Serializable id);
public void removeObject(Object o);
public void removeAllObject(Collection collection);
public Object findBy(Class clazz , String name, Object value);
public List findLike(Class clazz, String name, String value);
public List findAllBy(Class clazz , String name, Object value);
public void flush();
}
以下是实现类,我感觉还行基本的增删改查都有,拿出来分享下:
package com.ssh.neb.daoImpl;
import java.io.Serializable;
import java.util.Collection;
import java.util.List;
import org.hibernate.Criteria;
import org.hibernate.criterion.Restrictions;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;
import com.ssh.neb.dao.BaseDao;
public class BaseDaoImpl extends HibernateDaoSupport implements BaseDao {
public List findAllBy(Class clazz, String name, Object value) {
Criteria cr = getSession().createCriteria(clazz);
cr.add(Restrictions.in(name, new Object[]{value}));
List list = cr.list();
return list;
}
public Object findBy(Class clazz, String name, Object value) {
Criteria cr = getSession().createCriteria(clazz);
cr.add(Restrictions.in(name, new Object[]{value}));
return cr.list().get(0);
}
public List findLike(Class clazz, String name, String value) {
Criteria cr = getSession().createCriteria(clazz);
cr.add(Restrictions.like(name, "%"+value+"%"));
return cr.list();
}
public void flush() {
getHibernateTemplate().flush();
}
public List getAllObject(Class clazz) {
return this.getHibernateTemplate().loadAll(clazz);
//return getHibernateTemplate().loadAll(clazz);
}
public Object getObject(Class clazz, Serializable id) {
return getHibernateTemplate().load(clazz, id);
}
public void removeAllObject(Collection collection) {
getHibernateTemplate().deleteAll(collection);
}
public void removeObject(Class clazz, Serializable id) {
Object object = this.getHibernateTemplate().load(clazz, id);
getHibernateTemplate().delete(object);
}
public void removeObject(Object o) {
getHibernateTemplate().delete(o);
}
public void saveObject(Object o) {
getHibernateTemplate().saveOrUpdate(o);
}
public Object find(String queryString, Object[] values) {
Object object = null;
List list = getHibernateTemplate().find(queryString, values);
if(list.size()>0)
object = list.get(0);
return object;
}
public List findList(String queryString, Object[] values) {
return getHibernateTemplate().find(queryString, values);
}
}