HibernateTemplate常用方法

一.  HibernateTemplate常用方法

      void delete(Object entity):删除指定持久化实例

      deleteAll(Collection entities):删除集合内全部持久化类实例

      find(String queryString):根据HQL查询字符串来返回实例集合

      findByNamedQuery(String queryName):根据命名查询返回实例集合

      get(Class entityClass, Serializable id):根据主键加载特定持久化类的实例

      save(Object entity):保存新的实例

      saveOrUpdate(Object entity):根据实例状态,选择保存或者更新

      update(Object entity):更新实例的状态,要求entity是持久状态

      setMaxResults(int maxResults):设置分页的大

二.HibernateTemplate的两种用法

      一,常规的用法

         HibernateTemplate通过它自己的delete(Object entity) ,find(String queryString),save(Object entity)等等常用的方法即可完成大多数DAO对象的增,删,改,查(CURD)等操作。

      二,复杂的用法

         HibernateTemplate的复杂的用法是通过如下的两个方法来完成的:

            ●Object execute(HibernateCallback action)

            ●List execute(HibernateCallback action)

         这两个方法都需要一个HibernateCallback实例,程序开发者通过HibernateCallback,可以完全使用Hibernate灵活的方式来访问数据库,解决了Spring封装Hibernate后灵活不足的缺陷。HibernateCallback是一个接口,该接口只有一个方法doInHibernate(org.hibernate.Session session),该方法只有一个参数Session。

         通常,程序中采用实现HibernateCallback的匿名内部类来获取HibernateCallback的实例,方法doInHibernate就是Spring执行的持久化操作。

三.实例

    1.查询:find(String quertString);

     List <Depart> list = hibernateTemplate().find("from Depart order by id desc ");

    2.删除:delete(Object entity)

    hibernateTemplate().delete(depart);

    3.分页

    

		List   list = hibernateTemplate.executeFind(new HibernateCallback() {
				public Object doInHibernate(Session session)
					throws HibernateException, SQLException {
					return session.createQuery("from Depart order by id desc").setFirstResult(
							(pageIndex - 1) * pageSize).setMaxResults(pageSize).list();
				}
			});


    4.分页

List list = hibernateTemplate.executeFind(new HibernateCallback() {

				public Object doInHibernate(Session session)
						throws HibernateException, SQLException {
					return session.createQuery(
							"from Depart where name like ? order by id desc").setParameter(
							0, "%" + name + "%").setFirstResult(
							(pageIndex - 1) * pageSize).setMaxResults(pageSize)
							.list();
				}
			});


5.复杂查询

List list = hibernateTemplate.executeFind(new HibernateCallback() {

				public Object doInHibernate(Session session)
						throws HibernateException, SQLException {
					return session.createQuery(
							"from Depart where name = '"+name+"' order by id desc")
							.list();
				}
			});

6.

Object  list=   hibernateTemplate.execute(new HibernateCallback() {
				public  Object doInHibernate(Session session)
					throws HibernateException, SQLException {//dhsd_admin_service where
					return  session.createSQLQuery("select max(sort) from  admin_depart where parentId='"+id+"'" ).uniqueResult();
				}
			});



 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值