码迷,mamicode.com
首页 > 其他好文 > 详细

Optional与Mybatis

时间:2018-05-11 20:39:01      阅读:215      评论:0      收藏:0      [点我收藏+]

标签:int   分页   插件   tco   des   arp   optional   传递   collect   

1、mybatis的@Param()参数传递的问题,与JDK1.8的Optional的返回值问题。使用Optional与spring-data-jpa和mybatis有啥区别?

使用spring-data-jpa可以使用Optional<实体>,这样的返回不会出错。

但是Mybatis不行,返回值不能是 Optional<实体>,这样子会报错,字段也传入不到mapperxml中。

 

2、mybatis的传递参数为集合(set,list)的问题。

问题原因:

技术分享图片

 

技术分享图片

 出错原因:collection写set,list或者collection,所以出错。

 

3、mybatis使用自定义的分页插件,查询记录条数,查询显示内容

 

public class PageResult<T> {
	private int currentPage;

	private int pageSize;

	private int totalPages;

	private long totalCount;

	private List<T> content;

	public int getCurrentPage() {
		return currentPage;
	}

	public void setCurrentPage(int currentPage) {
		this.currentPage = currentPage;
	}

	public int getPageSize() {
		return pageSize;
	}

	public void setPageSize(int pageSize) {
		this.pageSize = pageSize;
	}

	public int getTotalPages() {
		return totalPages;
	}

	public void setTotalPages(int totalPages) {
		int page= (int) (this.totalCount/pageSize);
		if(this.totalCount%pageSize>0){
			page++;
		}
		this.totalPages = page;
	}

	public long getTotalCount() {
		return totalCount;
	}

	public void setTotalCount(long totalCount) {
		this.totalCount = totalCount;
	}

	public List<T> getLContent() {
		return content;
	}

	public void setContent(List<T> content) {
		this.content = content;
	}

 页面传递的参数: 

currentPage 当前页,pageSize每页的数据条数
pageResult.setCurrentPage(currentPage);
pageResult.setPageSize(pageSize);
计算有多少条记录count:select count(*) from 表
pageResult.setTotalCount(count);pageResult.setTotalPages(pageResult.getTotalPages());

查询页面内容:

select * from 表 where 条件
order by 字段 什么顺序(desc还是asc)limit #{currentPage},#{pageSize}
pageResult.setContent(页面内容)
返回pageResult即可。

Optional与Mybatis

标签:int   分页   插件   tco   des   arp   optional   传递   collect   

原文地址:https://www.cnblogs.com/fengli9998/p/9025953.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!