BaseDAO

package com.daacc.dao;

import java.sql.SQLException;
import java.util.List;

import org.hibernate.HibernateException;
import org.hibernate.Query;
import org.hibernate.Session;
import org.springframework.orm.hibernate3.HibernateCallback;
import org.springframework.orm.hibernate3.support.HibernateDaoSupport;

public class BaseDAO extends HibernateDaoSupport {

    
/**
     * 使用hql 语句进行分页查询操作
     * 
     * 
@param hql
     *            需要查询的hql语句
     * 
@param offset
     *            第一条记录索引
     * 
@param pageSize
     *            每页需要显示的记录数
     * 
@return 当前页的所有记录
     
*/
    
public List findByPage(final String hql, final int offset,
            
final int pageSize) {

        List list 
= getHibernateTemplate().executeFind(new HibernateCallback() {
            
public Object doInHibernate(Session session)
                    
throws HibernateException, SQLException {
                List result 
= session.createQuery(hql).setFirstResult(offset)
                        .setMaxResults(pageSize).list();
                
return result;
            }
        });
        
return list;
    }

    
/**
     * 使用hql 语句进行分页查询操作
     * 
     * 
@param hql
     *            需要查询的hql语句
     * 
@param value
     *            如果hql有一个参数需要传入,value就是传入的参数
     * 
@param offset
     *            第一条记录索引
     * 
@param pageSize
     *            每页需要显示的记录数
     * 
@return 当前页的所有记录
     
*/
    
public List findByPage(final String hql, final Object value,
            
final int offset, final int pageSize) {

        List list 
= getHibernateTemplate().executeFind(new HibernateCallback() {
            
public Object doInHibernate(Session session)
                    
throws HibernateException, SQLException {
                List result 
= session.createQuery(hql).setParameter(0, value)
                        .setFirstResult(offset).setMaxResults(pageSize).list();
                
return result;
            }
        });
        
return list;
    }

    
/**
     * 使用hql 语句进行分页查询操作
     * 
     * 
@param hql
     *            需要查询的hql语句
     * 
@param values
     *            如果hql有多个个参数需要传入,values就是传入的参数数组
     * 
@param offset
     *            第一条记录索引
     * 
@param pageSize
     *            每页需要显示的记录数
     * 
@return 当前页的所有记录
     
*/
    
public List findByPage(final String hql, final Object[] values,
            
final int offset, final int pageSize) {

        List list 
= getHibernateTemplate().executeFind(new HibernateCallback() {
            
public Object doInHibernate(Session session)
                    
throws HibernateException, SQLException {
                Query query 
= session.createQuery(hql);
                
for (int i = 0; i < values.length; i++) {
                    System.out.println(
"in BaseDAO:values[" + i + "]:"
                            
+ values[i]);
                    query.setParameter(i, values[i]);

                }
                List result 
= query.setFirstResult(offset).setMaxResults(
                        pageSize).list();
                
return result;
            }
        });
        
return list;
    }

    
public int findMaxIdFromObj(String obj) {

        String hql 
= "select max(id) from " + obj;
        System.out.println(
"hql:" + hql);
        List maxlist 
= (List) getHibernateTemplate().find(hql);
        System.out.print(maxlist.get(
0).toString());
        
return Integer.parseInt(maxlist.get(0).toString());
    }

}
 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值