Mybaties分页插件使用, 参数校验以及全局异常处理

简介: 本文教你快速进行Mybaties分页插件使用, 参数校验以及全局异常处理

大家好, 我是时间静止~~~ , 今天我们来学习Mybaties分页插件使用, 参数校验以及全局异常处理

分页插件使用

  1. 引入jar包坐标, 这里进行了自动配置, 因此不需要重新创建bean或者配置类

 <!--分页插件-->
       <!-- pagehelper分页插件 -->
       <dependency>
           <groupId>com.github.pagehelper</groupId>
           <artifactId>pagehelper</artifactId>
           <version>5.2.0</version>
       </dependency>
       <dependency>
           <groupId>com.github.pagehelper</groupId>
           <artifactId>pagehelper-spring-boot-autoconfigure</artifactId>
           <version>1.3.0</version>
       </dependency>
       <dependency>
           <groupId>com.github.pagehelper</groupId>
           <artifactId>pagehelper-spring-boot-starter</artifactId>
           <version>1.3.0</version>
       </dependency>

  1. service层 (不是在controller层哦)

   @Override
   public PageInfo<VersionRecord> selectList(Integer pageNum, Integer pageSize, Integer updateType) {
    //1. 开启分页
       PageHelper.startPage(pageNum,pageSize);
       //2. 接收list<object>集合
       List<VersionRecord> versionRecordList = versionRecordMapper.selectPageByupdateType(updateType);
       //3.
       PageInfo<VersionRecord> pageInfo = new PageInfo<>(versionRecordList);
       return pageInfo;
   }

  1. controller层

@GetMapping("selectList")
   public ResponseEntity selectList(@RequestParam(value = "pageNum",defaultValue = "1")Integer pageNum,
                                    @RequestParam(value = "pageSize",defaultValue = "10")Integer pageSize,
                                    @RequestParam(value = "updateType") Integer updateType) {
 
//直接返回这个分页对象即可
PageInfo<VersionRecord> versionRecordPageInfo = versionRecordService.selectList(pageNum, pageSize,updateType);

  1. 返回JSON文本格式

{
   "content": {
       "total": 3,
       "list": [
           {
               "versionId": 8,
               "updateType": 1,
               "versionNumber": "2.2.7",
               "versionSize": "193MB",
               "versionContent": "1.测试版本发布",
               "publishTime": "2021.11.04 15:48:49",
               "publishAccount": "admin",
               "updateState": 3,
               "fileUrl": "/upload/images/2.2.7.apk"
           },
           {
               "versionId": 6,
               "updateType": 1,
               "versionNumber": "2.2.6",
               "versionSize": "193MB",
               "versionContent": null,
               "publishTime": "2021.11.04 14:41:09",
               "publishAccount": "admin",
               "updateState": 3,
               "fileUrl": "/upload/images\\2.2.6.apk"
           },
           {
               "versionId": 5,
               "updateType": 1,
               "versionNumber": "2.2.6",
               "versionSize": "193MB",
               "versionContent": null,
               "publishTime": "2021.11.04 14:40:35",
               "publishAccount": "admin",
               "updateState": 3,
               "fileUrl": "/upload/images\\2.2.6.apk"
           }
       ],
       "pageNum": 1,
       "pageSize": 10,
       "size": 3,
       "startRow": 1,
       "endRow": 3,
       "pages": 1,
       "prePage": 0,
       "nextPage": 0,
       "isFirstPage": true,
       "isLastPage": true,
       "hasPreviousPage": false,
       "hasNextPage": false,
       "navigatePages": 8,
       "navigatepageNums": [
           1
       ],
       "navigateFirstPage": 1,
       "navigateLastPage": 1
   }
}

  1. 实际相当于执行了这样一条sql语句

select 查询列表
from
limit(page-1)*size ,size;
从n-1行后开始, 每行显示size个数据

分页查关键字询 特点: ①limit语句放在查询语句的,执行上语法上都在最后 ②公式, 要显示的页数page ,每页的条目数 size

参数校验以及全局异常处理

  1. jar坐标

 <!--参数校验-->
       <dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-validation</artifactId>
       </dependency>

  1. 使用注解即可

publicclassItem {

   @NotNull(message = "id不能为空")
   @Min(value = 1, message = "id必须为正整数")
   private Long id;

   @Valid// 嵌套验证必须用@Valid
   @NotNull(message = "props不能为空")
   @Size(min = 1, message = "props至少要有一个自定义属性")
   private List<Prop> props;
}

  1. 全局异常处理

/**
* 全局异常处理
*/

@RestControllerAdvice
publicclassGlobalExceptionHandler {
   /**
    * 当系统出现 MethodArgumentNotValidException 这个异常时,会调用下面的方法
    * @param e
    * @return
    */

   @ExceptionHandler(value = MethodArgumentNotValidException.class)
   publicResponseEntityjsonErrorHandler(MethodArgumentNotValidExceptione)
{
       ReturnCode returnCode = ReturnCode.OK;
       ResponseEntity responseEntity = null;

       List<Map<String,Object>> list=new ArrayList<>();
       List<ObjectError> allErrors = e.getBindingResult().getAllErrors();
       for (ObjectError allError : allErrors) {
           Map<String,Object> map=new HashMap<>();
           map.put("defaultMessage",allError.getDefaultMessage());
           map.put("objectName",allError.getObjectName());
           // 注意,这里面拿到具体的某一个属性
           FieldError fieldError= (FieldError) allError;
           map.put("field",fieldError.getField());
           list.add(map);
       }
       returnCode = ReturnCode.INFO_PARTID_FAIL;
       responseEntity = new ResponseEntity(returnCode);
       responseEntity.setContent(list);
       return responseEntity;
   }
}



==这个是返回实体
import com.example.callmachine.utils.ReturnCode;

import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

publicclassResponseEntity {

private ResponseHeader header = new ResponseHeader();
private Object content = new Object();

public ResponseHeader getHeader() {
 return header;
}

publicvoidsetHeader(ResponseHeader header) {
 this.header = header;
}

public Object getContent() {
 return content;
}

publicvoidsetContent(Object content) {
 this.content = content;
}

publicResponseEntity() {
}

publicResponseEntity(ReturnCode code) {
 this.header.setRtnCode(code.getCode());
 this.header.setReturnMsg(code.getMsg());
}

publicstatic String toJson(String returnCode, Object result) {
 ResponseHeader header = new ResponseHeader();
 header.setRtnCode(returnCode);
 header.setReturnMsg(ReturnCode.getReturnCodeByCode(returnCode).getMsg());
 ResponseEntity resEntity = new ResponseEntity();
 resEntity.setHeader(header);
 if (null != result) {
  resEntity.setContent(result);
 }
 return GsonUtils.toJson(resEntity);
}

publicstaticvoidsetResponse(HttpServletResponse response, String rspBody)throws IOException {
 response.setContentType("text/json;charset=UTF-8");// application/json
 response.getWriter().write(rspBody);
}
}


==返回码
publicenum ReturnCode {
//(00000 - 00999) System or common code
ERROR       ("0",     "失败"),
OK                           ("1",     "成功"),
SERVICE_NOT_FOUND            ("2",     "找不到系统服务"),
NO_DATA                ("3",     "暂无数据"),
ILLEGAL_ACCESS               ("4",     "非法访问"),
SYSTEM_ERROR                 ("999",   "系统错误"),
ReturnCode(String code, String msg) {
 this.code = code;
 this.msg = msg;
}

private String code;
private String msg;

public String getCode() {
 return code;
}

publicvoidsetCode(String code) {
 this.code = code;
}

public String getMsg() {
 return msg;
}

publicvoidsetMsg(String msg) {
 this.msg = msg;
}

//根据返回码获取返回对象
publicstatic ReturnCode getReturnCodeByCode(String code){
 for(ReturnCode returnCode : ReturnCode.values())
 {
  if(returnCode.getCode().equalsIgnoreCase(code))
   return returnCode;
 }  
 returnnull;
}



相关文章
|
开发框架 Oracle Java
JDK8和JDK17安装切换,IDEA配置多个版本JDK
JDK8和JDK17安装切换,IDEA配置多个版本JDK
|
应用服务中间件 网络安全 nginx
Nginx的安装使用卸载及配置ssl证书
nginx的安装以及基本配置,添加https证书,也就是ssl证书。
4417 0
|
Ubuntu Linux 开发工具
还在用虚拟机吗?通过WSL2在Win10下愉快的玩耍Linux(详细教程+报错解决方案)
还在用虚拟机吗?通过WSL2在Win10下愉快的玩耍Linux(详细教程+报错解决方案)
1162 1
还在用虚拟机吗?通过WSL2在Win10下愉快的玩耍Linux(详细教程+报错解决方案)
|
存储 运维 监控
经典好文:银行业IT服务连续性体系与灾备自动化切换经验分享
经典好文:银行业IT服务连续性体系与灾备自动化切换经验分享
761 0
|
数据库 Android开发 数据安全/隐私保护
Android中对sqlite加密--SQLCipher
原文:Android中对sqlite加密--SQLCipher android中有些时候会将一些隐私数据存放在sqlite数据库中,在root过的手机中通过RE就能够轻松的打开并查看数据库所有内容,所以对隐私数据的保护就有两个方法:①将隐私数据自行加密后存入数据库,别人即使打开查看也不知道是什么数据;②将整个数据库进行加密,别人根本就打不开。
2702 0
|
Python
Python 压缩PDF减小文件大小
【8月更文挑战第6天】介绍了三种用Python压缩PDF文件的方法:1) 使用`pdfcompressor`库,安装后可通过简单命令压缩文件;2) 利用`PyPDF2`库,需手动设置压缩参数;3) 采用`pdfsizeopt`库,一键优化PDF大小。各方法均提供示例代码,便于快速实现文件压缩。
2007 0
|
JavaScript 前端开发 Java
小笔记:表 - 各种语言的 CommonMark Markdown解析器 实现
小笔记:表 - 各种语言的 CommonMark Markdown解析器 实现
1199 1
|
分布式计算 Scala 开发工具
IntelliJ IDEA编写Scala代码(安装Scala插件)
IntelliJ IDEA编写Scala代码(安装Scala插件)
1513 0
IntelliJ IDEA编写Scala代码(安装Scala插件)
|
SQL 关系型数据库 MySQL
在 MySQL 中使用 `REPLACE` 函数
【8月更文挑战第8天】
2778 7
在 MySQL 中使用 `REPLACE` 函数

热门文章

最新文章