小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

使用擴(kuò)展HibernateDaoSupport實(shí)現(xiàn)分頁(yè)技術(shù)總結(jié)

 zengbj 2009-08-21
1.定義MyHibernateDaoSupport 擴(kuò)展HibernateSupport

mport 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 MyHibernateDaoSupport extends HibernateDaoSupport {
 public List findByPage(final String hql,final int offset,final int pageSize)
 {
  List list=this.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;
 }
 public List findByPage(final String hql,final String value,final int offset,final int pageSize)
 {
  List list=this.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;
 }
 public List findByPage(final String hql,final Object[] values,final int offset,final int pageSize){
  List list=this.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++)
    {
     query.setParameter(i,values[i]);
    }
    List result=query.setFirstResult(offset).setMaxResults(pageSize).list();
    return result;
   }
  }
  );
  return list;
 }
}


2.定義要分頁(yè)的實(shí)體的Dao接口
如:
public interface StudentDao {
 Student get(int id);
 void save(Student student);
 void update(Student student);
 void delete(int id);
 void delete(Student student);
 List<Student> findAll();
 List<Student> findAllByPage(int pageNo,int pageSize);
 int getStudentCount();

 List<Student> findStudentByNameAndNumber(String stuName,String stuNumber);
}
3.定義實(shí)現(xiàn)類(lèi)
主要寫(xiě)出兩個(gè)分頁(yè)中要用到的方法
public List<Student> findAllByPage(int pageNo, int pageSize) {
  if(pageNo<1){
   return null;
  }
  int offset=(pageNo-1)*pageSize;
  return findByPage("from Student", offset, pageSize);
 }
 public int getStudentCount() {
  List<Student> listStudent=this.getHibernateTemplate().find("from Student");
  return listStudent.size();
 }

4.定義Service接口
public interface ExamService {
 int STUDENT_PAGE_SIZE=3;
 int QUESTION_PAGE_SIZE=3;
 int addStudent(String stuNumber,String name,String className,String humanId,String email,String address,String phone) throws Exception;
 void deleteStudent(int id) throws Exception;
 List<Student> listStudent(int pageNo) throws Exception;
 int addQuestion(String quTitle,String quHard,String quScore,String quAnswer,String quType,String selectOption,int typeid) throws Exception;
 void deleteQuestion(int id) throws Exception;
 List<Question> listQuestion(int pageNo) throws Exception;
 void deleteExamtype(int typeid) throws Exception;
 int addExamtype(String textName,String testTime)throws Exception;
 List<Examtype> getAllExamtype()throws Exception;
 boolean adminLogin(String admName,String admPwd)throws Exception;
 int getStudentCount()throws Exception;
 int getQuestionCount()throws Exception;
 int getPageCount(int count,int pageSize);
 String studentLogin(String stuName,String stuNumber)throws Exception;
 Question getNextQuestion(List<Integer> alreadys,int typeid)throws Exception;
 Question getQuestionById(int id)throws Exception;
 String getExamtypeName(int typeid)throws Exception;;
}
5.定義實(shí)現(xiàn)類(lèi)
public int getPageCount(int count, int pageSize) {
  return (count+pageSize-1)/pageSize;
 }
public int getStudentCount() throws Exception {
  return studentDao.getStudentCount();
 }

public List<Student> listStudent(int pageNo) throws Exception {

  return studentDao.findAllByPage(pageNo, STUDENT_PAGE_SIZE);

 }

6.ListStudentAction.java
int studentCount=examService.getStudentCount();
  ActionMessages errors=new ActionMessages();
  if(studentCount<1)
  {
   errors.add("studentCount",new ActionMessage("studentCount.null"));
   mapping.findForward("success");
  }
  int pageCount=examService.getPageCount(studentCount,examService.STUDENT_PAGE_SIZE);
  int pageNo;
  if(request.getParameter("pageNo")==null || request.getParameter("pageNo").trim().equals(""))
  {
   pageNo=1;
  }
  try {
   pageNo=Integer.parseInt(request.getParameter("pageNo").trim());
  } catch (Exception e) {
   pageNo=1;
  }
  if(pageNo>pageCount){
   pageNo=pageCount;
  }
  request.setAttribute("pageCount",pageCount);
  request.setAttribute("currentPage",pageNo);
  request.setAttribute("studentList", examService.listStudent(pageNo));
  return mapping.findForward("success");
7.listStudent.jsp

<table cellspacing="0" cellpadding="0" border="1" width="700">
  <tr>
   <th>
    <bean:message key="student.shenfenzheng" />
   </th>
   <th>
    <bean:message key="student.mingzi" />
   </th>
   <th>
    <bean:message key="student.banji" />
   </th>
   <th>
    <bean:message key="student.xuehao" />
   </th>
   <th>
    <bean:message key="student.youjian" />
   </th>
   <th>
    <bean:message key="student.dianhua" />
   </th>
   <th>
    <bean:message key="student.address" />
   </th>
   <th>
    <bean:message key="student.isdelete" />
   </th>
  </tr>
  <c:forEach items="${requestScope.studentList}" var="students">
   <tr>
    <td align="center">
     ${students.humanId}
    </td>
    <td align="center">
     ${students.stuName}
    </td>
    <td align="center">
     ${students.stuClassName}
    </td>
    <td align="center">
     ${students.stuNumber}
    </td>
    <td align="center">
     ${students.email}
    </td>
    <td align="center">
     ${students.phone}
    </td>
    <td align="center">
     ${students.address}
    </td>
    <td align="center">
     <a href="deleteStudent.do?delStuid=${students.id}"
      onclick='return confirm("<bean:message key="confirm.del.student"/>");' target="center"><bean:message
       key="student.delete" />
     </a>
    </td>
   </tr>
  </c:forEach>
  <br />
  <tr>
   <td colspan="7" align="center">
    第${requestScope.currentPage}頁(yè)  共${requestScope.pageCount}頁(yè)
    <a href="listStudent.do?pageNo=1">首頁(yè)</a> 
    <logic:greaterThan value="1" name="currentPage" scope="request">
     <a href="listStudent.do?pageNo=${requestScope.currentPage-1}">
    </logic:greaterThan>
    上一頁(yè)
    <logic:greaterThan value="1" name="currentPage" scope="request">
     </a>
    </logic:greaterThan>

    <logic:lessThan value="${requestScope.pageCount}" name="currentPage"
     scope="request">
     <a href="listStudent.do?pageNo=${requestScope.currentPage+1}">
    </logic:lessThan>
    下一頁(yè)
    <logic:lessThan value="${requestScope.pageCount}" name="currentPage"
     scope="request">
     </a>
    </logic:lessThan>
    <a href="listStudent.do?pageNo=${requestScope.pageCount}">尾頁(yè)</a> 
   </td>
  </tr>
 </table>

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶(hù)發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶(hù) 評(píng)論公約