一,需求:

CommonQuery--PyQueryBean

PyQueryBean:鹏飞历史记录查询,以往哪些人对征信进行了查询。
CommonQuery:查询条件:根据查询人(umName)、被查询人姓名(name)、身份证号(documentNo)、手机号(phone)、查询日期(queryDate)
二,配置相关:
1,mybatis-config.xml

<!-- 配置分页插件 -->
<plugins>
<plugin interceptor="com.github.pagehelper.PageInterceptor">
<!-- 设置数据库类型 Oracle,Mysql,MariaDB,SQLite,Hsqldb,PostgreSQL六种数据库-->
<property name="helperDialect" value="mysql"/>
</plugin>
</plugins>
复制代码
2,pom依赖
 <!-- mybatis分页 -->
<dependency>
<groupId>com.github.pagehelper</groupId>
<artifactId>pagehelper</artifactId>
<version>5.1.2</version>
</dependency>
三,代码
Controller
/**
* @param request, pyQueryBean
* @return com.pingan.credit.model.ResponseResult<java.util.List<com.pingan.credit.model.py.PyQueryBean>>
* @Description: 历史记录查询
* @date 2017/11/23 17:00
*/
@RequestMapping(path = "/queryPyHistoryRecord", method = {RequestMethod.GET, RequestMethod.POST})
@ResponseBody
public ResponseResult<BasePageInfo<PyQueryBean>> queryPyHistoryRecord(HttpServletRequest request, CommonQuery commonQuery) {
ResponseResult<BasePageInfo<PyQueryBean>> responseResult = new ResponseResult<>();
try {
BasePageInfo<PyQueryBean> pageInfo = pyQueryService.queryHistoryRecord(commonQuery);
responseResult.setData(pageInfo);
responseResult.setRet(SUCCESS);
responseResult.setRefID(commonQuery.getRefID());
responseResult.setTimestamp(DateUtil.getTimeStamp().toString());
} catch (CreditException e) {
responseResult.setErrorCode(e.getErrorCode());
responseResult.setRet(SUCCESS);
responseResult.setErrorMsg(e.getMessage());
} catch (Exception e) {
responseResult.setErrorCode(PyCreditServiceErrorEnum.SYSTEM_ERROR.getCode());
responseResult.setRet(FAILED);
responseResult.setErrorMsg(PyCreditServiceErrorEnum.SYSTEM_ERROR.getMsg());
}
return responseResult;
}
接口响应类
public class ResponseResult<T> extends BasePojo {
/**成功标识符 **/
private boolean ret;
/** 异常信息**/
private String errorMsg;
/** 返回数据类型 **/
private T data;
/** 异常码 **/
private String errorCode;
/** 请求ID**/
private String refID;
/** 时间戳 **/
private String timestamp;
--响应结果类
public class PyQueryBean extends BaseQuery implements Serializable { private transient int id;
/**查询者姓名,不允许为空**/
private String name; //被查询者证件号码,不允许为空
private String documentNo; //被查询者手机号码,反欺诈的报告不允许为空 深圳个人征信可以为空
private String phone;
//查询原因ID,只能传本单位允许的查询原因 101
private String queryReasonID;
//96040 反欺诈 90008 深圳个人信用
private String subreportIDs; //引用ID,查询者提交的用于识别本次查询的流水号,系统返回结果中会原样包含该流水号。可以为空。
private String refID; private String umName;
//证件类型
private String documentType;
//报告
private String docId;
//查询日期
private String queryDate;
//查询类型
@JSONField(serialize = false )
private Integer queryType; private String imageId; //是否直连 1:直连
private Integer queryFromPy;
**
* 分页查询类
** @date 2017/11/29 15:54
**/
public class BasePageInfo<T>{ /**
* 总记录数
**/
private long total;
/**
* 结果集
**/
private List<T> list;
/**
* 第几页
**/
private int pageNum;
/**
* 每页记录数
*/
private int pageSize;
/**
* 总页数
**/
private int pages;
/**
* 当前页的数量 <= pageSize,该属性来自ArrayList的size属性
**/
private int size; /**
* 包装Page对象,因为直接返回Page对象,在JSON处理以及其他情况下会被当成List来处理,
* 而出现一些问题。
*
* @param list page结果
*/
public BasePageInfo(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();
}
}

**
* 通用查询类,封装查询条件* @date 2017/11/29 9:27
**/
public class CommonQuery extends BaseQuery {
/**
* 姓名
**/
private String name;
/**
* 身份证号
**/
private String documentNo;
/**
* 手机号
**/
private String phone;
/**
* 查询起始日期
**/
private String startDate;
/**
* 查询终止日期
**/
private String endDate;
/**
* 查询方式
**/
private String queryWay;
/**
* um帐号
**/
private String umName;
/**
* 引用ID
**/
private String refID;
/**
* 查询页码
**/
private int page;
/**
* 页面展示数量
**/
private int pageSize;
Service
    /**
* @param commonQuery, type, pageNum, pageSize
* @return com.github.pagehelper.PageInfo<com.pingan.credit.model.py.PyQueryBean>
* @Description: 根据查询人(umName)、被查询人姓名(name)、身份证号(documentNo)、手机号(phone)、查询日期(queryDate)
* @date 2017/11/29 9:24
*/
@Override
public BasePageInfo<PyQueryBean> queryHistoryRecord(CommonQuery commonQuery) throws Exception {
try {
logger.info("queryHistoryRecord ... ");
Map<String, Object> map = new HashMap<>();
map.put("obj", commonQuery);
PageHelper.startPage(commonQuery.getPage(), commonQuery.getPageSize());
List<PyQueryBean> list = queryRecordMapper.selectQueryRecordByCondition(map);
BasePageInfo<PyQueryBean> result = new BasePageInfo<>(list);
result.setList(list);
logger.info(JSON.toJSONString(list));
return result;
} catch (Exception e) {
logger.error("level0_queryHistoryRecord@PyQueryServiceImpl_Exception", e);
throw e;
} }
sql
<!-- 根据条件查询出历史记录 -->
<select id="selectQueryRecordByCondition" resultMap="BaseResultMap" parameterType="Map">
SELECT
name,documentNo,umName,to_char(queryDate,'yyyy-MM-dd hh24:mi:ss') as
queryDate,queryWay,queryReasonCode,queryReason
FROM ICS_PY_QUERYRECORD
<trim prefix="WHERE" prefixOverrides="AND | OR ">
<if test="obj.startDate !=null and obj.startDate !='' ">
<![CDATA[ AND QUERYDATE> to_date(#{obj.startDate,jdbcType=DATE},'yyyy-MM-dd hh24:mi:ss') ]]>
</if>
<if test="obj.endDate !=null and obj.endDate !='' ">
<![CDATA[ AND QUERYDATE<=to_date(#{obj.endDate,jdbcType=DATE},'yyyy-MM-dd hh24:mi:ss' )]]>
</if>
<if test="obj.umName != null and obj.umName !=''">
AND UMNAME = #{obj.umName,jdbcType=VARCHAR}
</if>
<if test="obj.name != null and obj.name !=''">
AND NAME = #{obj.name,jdbcType=VARCHAR}
</if>
<if test="obj.queryWay !=null and obj.queryWay !='' ">
AND QUERYWAY = #{obj.queryWay,jdbcType=VARCHAR}
</if>
<if test="obj.queryReasonCode !=null and obj.queryReasonCode !='' ">
AND QUERYREASONCODE = #{obj.queryReasonCode,jdbcType=VARCHAR}
</if>
</trim>
ORDER BY QUERYDATE DESC
</select>
 

 





插件PageHelper实现分页查询的更多相关文章

  1. SpringBoot 使用 MyBatis 分页插件 PageHelper 进行分页查询

    前言:本文档使用的是 SpringBoot,如果是 Spring 还需要在 MyBatis 配置 xml 中配置拦截器,并且 PageHelper 是针对 MyBatis 的,MyBatis 的集成不 ...

  2. ssm+PageHelper实现分页查询

    通过搭建ssm框架,然后通过mybatis的分页插件pagehelp进行分页查询.源码:https://gitee.com/smfx1314/pagehelper 看一下项目结构: 首先创建一个mav ...

  3. PageHelper实现分页查询

    PageHelper是基于拦截器实现的myBatis分页插件 PageHelper的Github主页 : https://github.com/pagehelper/Mybatis-PageHelpe ...

  4. ssm下使用分页插件PageHelper进行分页

    1. 导入maven依赖: <dependency> <groupId>com.github.pagehelper</groupId> <artifactId ...

  5. 使用PageHelper进行分页查询

    service层代码: public Result getDataSetList(String dataCode, String dataName, int pageIndex, int length ...

  6. Springboot 使用pageHelper实现分页查询

    本文链接:https://blog.csdn.net/qq_35387940/article/details/91530234

  7. 基于Mybatis分页插件PageHelper

    基于Mybatis分页插件PageHelper 1.分页插件使用 1.POM依赖 PageHelper的依赖如下.需要新的版本可以去maven上自行选择 <!-- PageHelper 插件分页 ...

  8. (转)淘淘商城系列——MyBatis分页插件(PageHelper)的使用以及商品列表展示

    http://blog.csdn.net/yerenyuan_pku/article/details/72774381 上文我们实现了展示后台页面的功能,而本文我们实现的主要功能是展示商品列表,大家要 ...

  9. 5-7 分页查询PageHelper

    1. PageHelper实现分页查询 Day08 1.1 PH作用: PageHelper框架可以实现我们提供页码和每页条数, 自动实现分页效果,收集分页信息 1.2 PH原理: PageHelpe ...

随机推荐

  1. 【TCP/IP详解 卷一:协议】第十章 动态选路协议

    更为详细的RIP博客解析: RIP理论 距离向量算法的简介: RIP协议V-D算法的介绍 10.1 引言 静态选路修改路由表的三种方法 (1)主机设置时,默认的路由表项 (2)ICMP重定向报文(默认 ...

  2. workerman如何写mysql连接池

    首先要了解为什么用连接池,连接池能为你解决什么问题 连接池主要的作用1.减少与数据服务器建立TCP连接三次握手及连接关闭四次挥手的开销,从而降低客户端和mysql服务端的负载,缩短请求响应时间2.减少 ...

  3. Java编程语言下 Selenium 驱动各个浏览器代码

    这里采用的是Selenium3.7版本,首先介绍的是在Windows环境下运行的: 总结下注意事项: 1,设置各个浏览器的Driver路径 System.setProperty("" ...

  4. 设置网站URL启动

    当新建一个MVC WEB程序 当你打开一个视图按F5运行 这时候并且不能政策运行会出现与个错误 无法找到资源. 这时候站点的默认设置是 把这个个默认设置更改成 红色框框的地方为修改点 你以为这样就完了 ...

  5. 聊一聊 Cloud Native 与12-Factor

    12-Factor(twelve-factor),也称为“十二要素”,是一套流行的应用程序开发原则.Cloud Native架构中使用12-Factor作为设计准则. 12-Factor 的目标在于: ...

  6. js audio 播放音乐

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  7. 查找并替换字符串 Find And Replace in String

    2018-07-29 17:08:15 问题描述: 问题求解: 字符串替换的问题有个技巧就是从右向左进行替换,这样的话,左边的index就不需要考虑变动了. public String findRep ...

  8. m_Orchestrate learning system---三十四、使用重定义了$的插件的时候最容易出现的问题是什么

    m_Orchestrate learning system---三十四.使用重定义了$的插件的时候最容易出现的问题是什么 一.总结 一句话总结:如下面这段代码,定义了$的值,还是会习惯性的把$当成jQ ...

  9. Netty优雅退出机制和原理

    1.进程的优雅退出 1.1.Kill -9 PID带来的问题 在Linux上通常会通过kill -9 pid的方式强制将某个进程杀掉,这种方式简单高效,因此很多程序的停止脚本经常会选择使用kill - ...

  10. Linux crontab定时执行任务 命令格式与详细例子(转)

    基本格式 : * * * * * command 分 时 日 月 周 命令 第1列表示分钟1-59 每分钟用*或者 */1表示 第2列表示小时1-23(0表示0点) 第3列表示日期1-31 第4列表示 ...