> Java > java지도 시간 > SpringMvc+Mybatis+Pagehelper 페이징 상세 설명

SpringMvc+Mybatis+Pagehelper 페이징 상세 설명

高洛峰
풀어 주다: 2017-01-07 10:27:24
원래의
2290명이 탐색했습니다.

최근 회사에서 페이징이 필요한 알람 페이지 기능을 만들어야 하는데 많은 정보를 확인한 결과 PageHelper가 더 적합하다고 판단했습니다.

그래서 PageHelper 사용에 대한 튜토리얼을 처음부터 작성했습니다.

1. 먼저 프로젝트에 PageHelper 종속성을 추가해야 합니다.

<dependency> 
 <groupId>com.github.pagehelper</groupId> 
 <artifactId>pagehelper</artifactId> 
 <version>4.1.6</version> 
</dependency>
로그인 후 복사

2. mybatis 구성 파일의 pagehelper 구성

<configuration>   
  <plugins>  
    <!-- com.github.pagehelper为PageHelper类所在包名 -->  
    <plugin interceptor="com.github.pagehelper.PageHelper">  
      <!-- 4.0.0以后版本可以不设置该参数 -->  
      <property name="dialect" value="mysql"/>  
      <!-- 该参数默认为false -->  
      <!-- 设置为true时,会将RowBounds第一个参数offset当成pageNum页码使用 -->  
      <!-- 和startPage中的pageNum效果一样-->  
      <property name="offsetAsPageNum" value="true"/>  
      <!-- 该参数默认为false -->  
      <!-- 设置为true时,使用RowBounds分页会进行count查询 -->  
      <property name="rowBoundsWithCount" value="true"/>  
      <!-- 设置为true时,如果pageSize=0或者RowBounds.limit = 0就会查询出全部的结果 -->  
      <!-- (相当于没有执行分页查询,但是返回结果仍然是Page类型)-->  
      <property name="pageSizeZero" value="true"/>  
      <!-- 3.3.0版本可用 - 分页参数合理化,默认false禁用 -->  
      <!-- 启用合理化时,如果pageNum<1会查询第一页,如果pageNum>pages会查询最后一页 -->  
      <!-- 禁用合理化时,如果pageNum<1或pageNum>pages会返回空数据 -->  
      <property name="reasonable" value="true"/>  
      <!-- 3.5.0版本可用 - 为了支持startPage(Object params)方法 -->  
      <!-- 增加了一个`params`参数来配置参数映射,用于从Map或ServletRequest中取值 -->  
      <!-- 可以配置pageNum,pageSize,count,pageSizeZero,reasonable,orderBy,不配置映射的用默认值 -->  
      <!-- 不理解该含义的前提下,不要随便复制该配置 -->  
      <!-- <property name="params" value="pageNum=start;pageSize=limit;"/> -->  
      <!-- 支持通过Mapper接口参数来传递分页参数 -->  
      <property name="supportMethodsArguments" value="true"/>  
      <!-- always总是返回PageInfo类型,check检查返回类型是否为PageInfo,none返回Page -->  
      <property name="returnPageInfo" value="check"/>  
    </plugin>  
  </plugins>  
</configuration>
로그인 후 복사

3. 페이징 정보를 저장하기 위한 PageBean 클래스 추가

public class PageBean<T> implements Serializable { 
   private static final long serialVersionUID = 1L; 
    private long total; //总记录数 
    private List<T> list; //结果集 
    private int pageNum; //第几页 
    private int pageSize; //每页记录数 
    private int pages; // 总页数 
    private int size; //当前页的数量<=pageSize 
  
    public PageBean(List<T> list){ 
      if (list instanceof Page){ 
        Page<T> page = (Page<T>) list; 
        this.pageNum = page.getPageNum(); 
        this.pageSize = page.getPageSize(); 
        this.total = page.getTotal(); 
        this.pages = page.getPages(); 
        this.list = page; 
        this.size = page.size(); 
      } 
    } 
    public long getTotal() { 
      return total; 
    } 
    public void setTotal(long total) { 
      this.total = total; 
    } 
    public List<T> getList() { 
      return list; 
    } 
    public void setList(List<T> list) { 
      this.list = list; 
    } 
    public int getSize() { 
      return size; 
    } 
    public void setSize(int size) { 
      this.size = size; 
    } 
    public int getPageNum() { 
      return pageNum; 
    } 
    public void setPageNum(int pageNum) { 
      this.pageNum = pageNum; 
    } 
    public int getPageSize() { 
      return pageSize; 
    } 
    public void setPageSize(int pageSize) { 
      this.pageSize = pageSize; 
    } 
    public int getPages() { 
      return pages; 
    } 
    public void setPages(int pages) { 
      this.pages = pages; 
    } 
  }
로그인 후 복사

다음은 비즈니스 로직 코드입니다

4. 먼저 mapper.xml 파일을 작성하고, 데이터베이스의 SQL을 연산하여 필요한 데이터를 찾아냅니다

<select id="selectallList" parameterType="com.alarm.bean.AlarmParamModel"
  resultMap="AlarmMap"> 
  select message_id, seqnum, message_type, process_status, 
  distribute_status, processor, occur_time, close_time,  
  system_id, group_id, warn_level, message_content 
  from td_alarm_info 
</select>
로그인 후 복사

5. Mapper 인터페이스 방식

public List<AlarmParamModel> selectallList(AlarmParamModel model);
로그인 후 복사

6. 서비스의 인터페이스 방식

Datagrid selectallList(AlarmParamModel model,int pageNum, int pageSize);
로그인 후 복사

7. 서비스의 구현 클래스

여기서 주목해야 할 것은 페이징의 주요 논리입니다. pageNum은 페이지 번호를 나타내고, pageSize는 각 페이지에 표시되는 숫자를 나타내며, startPag 메소드는 초기 페이지, orderBy 메소드는 특정 필드별로 데이터를 정렬하는 것입니다. 여기서는 occr_time의 내림차순(desc)을 사용합니다

public Datagrid selectallList(AlarmParamModel model,int pageNum, int pageSize){
    PageHelper.startPage(pageNum, pageSize);
    PageHelper.orderBy("occur_time desc");
     List<AlarmParamModel> list = this.alarmMgrMapper.selectallList(model);
     PageInfo<AlarmParamModel> pageInfo = new PageInfo<AlarmParamModel>(list);
    Datagrid datagrid = new Datagrid(pageInfo.getTotal(),pageInfo.getList());
     return datagrid;
  }
로그인 후 복사

8. 여기서는 총 개수(total number)와 행(data)을 포함한 데이터를 프런트 데스크로 전송하는 데 사용되는 Datagrid 클래스를 사용합니다. )

public class Datagrid {
  private long total;
  private List rows = new ArrayList<>();
  public Datagrid() {
    super();
  }
  public Datagrid(long total, List rows) {
    super();
    this.total = total;
    this.rows = rows;
  }
  public long getTotal() {
    return total;
  }
  public void setTotal(long total) {
    this.total = total;
  }
  public List getRows() {
    return rows;
  }
  public void setRows(List rows) {
    this.rows = rows;
  }
}
로그인 후 복사

9. 컨트롤러 레이어 작성을 시작하고

이전에 작성한 메소드를 호출합니다. 여기서 주목해야 할 것은 해당 오프셋입니다. 페이지 번호와 각 페이지에 표시되는 숫자는 bootstraptable의 오프셋과 한도와 다릅니다. 즉, 각 페이지에 10개의 데이터가 표시되면 오프셋이 표시됩니다. 부트스트랩에서 두 번째 페이지가 나타내는 오프셋은 10이고, 첫 번째 페이지와 세 번째 페이지는 각각 0과 20입니다. 그리고 여기서 오프셋은 pageNum을 나타냅니다.

@RequestMapping(value = "/AlarmInfo/list", method = {RequestMethod.GET,RequestMethod.POST})
  @ResponseBody
  public Datagrid alarmInfo(AlarmParamModel model,@RequestParam(value="offset",defaultValue="0",required=false)Integer pageNum, 
      @RequestParam(value="limit",defaultValue="10",required=false)Integer pageSize) 
  {
    Datagrid datagrid = this.alarmMgrService.selectallList(model,pageNum, pageSize);
    return datagrid;
  }
로그인 후 복사

10. 이제 프런트 엔드 요청에서 배경 데이터를 가져와 페이지를 매길 수 있습니다. 프런트 엔드 부트스트랩 테이블의 구성을 게시하겠습니다. .

$(&#39;#tb_departments&#39;).bootstrapTable({
      url: &#39;http://10.1.234.134:8088/api/AlarmInfo/list&#39;,     //请求后台的URL(*)
      method: &#39;get&#39;,           //请求方式(*)
      striped: false,           //是否显示行间隔色
      cache: false,            //是否使用缓存,默认为true,所以一般情况下需要设置一下这个属性(*)
      pagination: true,          //是否显示分页(*)
      onlyInfoPagination:true,     //设置为 true 只显示总数据数,而不显示分页按钮。需要 pagination=&#39;True&#39;
      sortable: true,           //是否启用排序
      sortOrder: "asc",          //排序方式
      queryParams: oTableInit.queryParams,//传递参数(*)
      sidePagination: "server",      //分页方式:client客户端分页,server服务端分页(*)
      pageNumber:1,            //初始化加载第一页,默认第一页
      pageSize: 10,            //每页的记录行数(*)
      pageList: [10, 25, 50, 100],    //可供选择的每页的行数(*)
      search: false,            //是否显示表格搜索,此搜索是客户端搜索,不会进服务端,所以,个人感觉意义不大
      strictSearch: true,
      showColumns: false,         //是否显示所有的列
      showRefresh: false,         //是否显示刷新按钮
      minimumCountColumns: 2,       //最少允许的列数
      clickToSelect: true,        //是否启用点击选中行
      checkboxHeader:true,       //add
      height: 500,            //行高,如果没有设置height属性,表格自动根据记录条数觉得表格高度
      uniqueId: "id",           //每一行的唯一标识,一般为主键列
      showToggle:false,          //是否显示详细视图和列表视图的切换按钮
      cardView: false,          //是否显示详细视图
      detailView: true,
      detailFormatter:detailFormatter ,
      paginationHAlign:"left",
      paginationDetailHAlign:"right",
로그인 후 복사

여기서는 부트스트랩과 함께 제공되는 페이징 버튼을 사용하지 않았습니다. jq를 사용하여 버튼 그룹을 직접 작성하겠습니다. 다음 글 코드를 올려서 커스터마이징 정도를 높여보세요~ 부트스트랩 가능 서브밴드의 페이징 버튼을 직접 사용해 구성을 변경할 수도 있습니다.

위는 편집자가 소개한 SpringMvc+Mybatis+Pagehelper 페이지네이션에 대한 자세한 설명입니다. 궁금한 점이 있으면 메시지를 남겨주세요. 시간 내에 답변해 드리겠습니다. 또한 PHP 중국어 웹사이트를 지원해 주신 모든 분들께 감사드립니다!

더 많은 SpringMvc+Mybatis+Pagehelper 페이지네이션 관련 글을 보시려면 PHP 중국어 홈페이지를 주목해주세요!


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿