一,需求:

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. 论文笔记:Mastering the game of Go with deep neural networks and tree search

    Mastering the game of Go with deep neural networks and tree search Nature 2015  这是本人论文笔记系列第二篇 Nature ...

  2. shiro的简单入门使用

    这里只是测试登录认证,没有web模块,没有连接数据库,用户密码放在shiro.ini配置中,密码没有加密处理,简单入门. 基于maven 先看目录结构 测试结果 pom.xml <?xml ve ...

  3. java web项目配置https访问

      转载: tomcat6配置:  1.单向认证,就是传输的数据加密过了,但是不会校验客户端的来源  2.双向认证,如果客户端浏览器没有导入客户端证书,是访问不了web系统的,找不到地址  如果只是加 ...

  4. springmvc基础知识及注解

    SpringMVC 1.概念 Spring的MVC框架是一个基于DispatcherServlet的MVC框架,主要由DispatcherServlet.处理器映射.处理器.视图解析器.视图组成.每一 ...

  5. ubuntu 14.04 (desktop amd 64) 下载

    http://cdimage.ubuntu.com/ubuntukylin/releases/14.04/release/

  6. pip 安装pandas报UnicodeDecodeError: 'ascii' codec can't decode byte 0xd5错

    当Python在window环境中通过pip安装pandas报标题这样的错,主要是因为python默认编码格式是:ascii 在https://www.python.org/dev/peps/pep- ...

  7. [ios][map]自定义地图标注

    参考:http://blog.csdn.net/mad1989/article/details/8794762 ios 一步一步学会自定义地图吹出框(CalloutView)-->(百度地图,高 ...

  8. 第一次学习 CG( c for graphic) 遇到的一大推坑

    1.CG开发环境的配置: 具体的工具包下载及整体的配置过程可以参考:https://blog.csdn.net/seamanj/article/details/8300936. 上面网址的内容是对VS ...

  9. html生成缩略图来预览解决方案

    html生成缩略图来预览解决方案 一.总结 一句话总结:先将html转化为canvas,然后将canvas生成图片ajax上传到服务器,就可以了 html 转化 canvas 图片 上传 html2c ...

  10. 一个或多个音频服务未运行 win7 错误1079:此服务的账户不同于运行于同一进程上的其他服务账户

    一个或多个音频服务未运行 win7 错误1079:此服务的账户不同于运行于同一进程上的其他服务账户 启动任务管理器:右键计算机——管理——”服务和应用程序“选项——”服务“——找到“windows a ...