java分页与排序orderby_mysql排序分页

java分页与排序orderby_mysql排序分页java分页与排序代码如下不解释代码如下不解释publicclassSortObimplementsComparable{privateStringname;privateintage;privateDatecreateDate;publicSortOb(Stringname,intage,DatecreateDate){ this.name=name; this.age=age; this.createDate=createDate;}

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

java分页与排序

代码 如下不解释

public class SortOb implements Comparable{

private String  name;
private int age;
private Date createDate;

public SortOb(String name,int age,Date createDate) {
	this.name = name;
	this.age = age;
	this.createDate = createDate;
}

public Date getCreateDate() {
	return createDate;
}

public void setCreateDate(Date createDate) {
	this.createDate = createDate;
}

public String getName() {
	return name;
}
public void setName(String name) {
	this.name = name;
}
public int getAge() {
	return age;
}
public void setAge(int age) {
	this.age = age;
}

// @Override
// public int compareTo(SortOb o) {

// return this.age – o.getAge();
// }
@Override
public int compareTo(SortOb o) {

try {

Date dt1 = o.getCreateDate();
Date dt2 = this.getCreateDate();
if (dt1.getTime() > dt2.getTime()) {

return -1;//小的放前面
}else {

return 1;
}
} catch (Exception e) {

e.printStackTrace();
}
return 0;
}
}

public class ListSortTest {

public static void main(String[] args) throws ParseException {
	List<SortOb> list = new ArrayList<SortOb>();
	DateFormat format1 = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
	Date dateA = format1.parse("2002-1-18 22:01:01");
	Date dateB = format1.parse("2001-1-18 22:01:01");
	Date dateC = format1.parse("2005-1-18 22:01:01");
	Date dateD = format1.parse("2004-1-18 22:01:01");
	Date dateE = format1.parse("2006-1-18 22:01:01");
	Date dateF = format1.parse("2003-1-18 22:01:01");
	Date dateG = format1.parse("2007-1-18 22:01:01");
	Date dateH = format1.parse("2009-1-18 22:01:01");
	Date dateI = format1.parse("2006-1-18 22:01:01");
	Date dateJ = format1.parse("2008-1-18 22:01:01");
	Date dateK = format1.parse("2010-1-18 22:01:01");
	Date dateL = format1.parse("2009-1-18 22:01:01");

	SortOb a = new SortOb("bb", 2,dateA);
	SortOb b = new SortOb("aa", 1,dateB);
	SortOb c = new SortOb("ee", 5,dateC);
	SortOb d = new SortOb("dd", 4,dateD);
	SortOb e = new SortOb("ff", 6,dateE);
	SortOb f = new SortOb("cc", 3,dateF);
	SortOb g = new SortOb("gg", 7,dateG);
	SortOb h = new SortOb("ii", 9,dateH);
	SortOb i = new SortOb("zz", 6,dateI);
	SortOb j = new SortOb("hh", 8,dateJ);
	SortOb k = new SortOb("hh", 10,dateK);
	SortOb l = new SortOb("jj", 9,dateL);
	list.add(a);
	list.add(b);
	list.add(c);
	list.add(d);
	list.add(e);
	list.add(f);
	list.add(g);
	list.add(h);
	list.add(i);
	list.add(j);
	list.add(k);
	list.add(l);
	Collections.sort(list, (SortOb b1, SortOb b2) -> b2.compareTo(b1));

	Map<String, Object> map = getPagingResultMap(list,2,10);
	List<SortOb> pageList = (List<SortOb>) map.get("result");

	for (SortOb ob : pageList) {
		SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
		String dateString = formatter.format(ob.getCreateDate());
		System.out.println(dateString);
	}

// for (SortOb ob : list) {

// System.out.println(ob.getAge());
// }

}

public static  Map<String, Object> getPagingResultMap(List<SortOb> list, Integer currPageNo, Integer pageSize) {
	Map<String, Object> retMap = new HashMap<>();

	if (list.isEmpty()) {
		retMap.put("result", Collections.emptyList());
		retMap.put("totalPageNum", 0);
		return retMap;
	}
	
	int totalRowNum = list.size();
	
	//页数超过数据总页数返回空list
	if (totalRowNum< pageSize * (currPageNo-1)) {
		retMap.put("result", Collections.emptyList());
		retMap.put("totalPageNum", totalRowNum);
		return retMap;
	}
	
	int totalPageNum = (totalRowNum - 1) / pageSize + 1;

	int realPageNo = currPageNo;
	if (currPageNo > totalPageNum) {
		realPageNo = totalPageNum;
	} else if (currPageNo < 1) {
		realPageNo = 1;
	}

	int fromIdx = (realPageNo - 1) * pageSize;
	int toIdx = realPageNo * pageSize > totalRowNum ? totalRowNum : realPageNo * pageSize;
			
	List<SortOb> result = list.subList(fromIdx, toIdx);
	
	retMap.put("result", result);
	retMap.put("totalPageNum", totalPageNum);
	return retMap;

}

// public static void main(String[] args) {

// int totalRowNum = 12;
// int pageSize = 10;
// int currPageNo = 2;
// System.out.println((totalRowNum< pageSize * (currPageNo-1)));
// }

}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/186497.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • export在linux中用法_from . import

    export在linux中用法_from . import镜像下载、域名解析、时间同步请点击阿里云开源镜像站export命令用于将shell变量输出为环境变量,或者将shell函数输出为环境变量。一个变量创建时,它不会自动地为在它之后创建的shell进程所知。而命令export可以向后面的shell传递变量的值。命令语法export[参数]命令参数-f:指向函数。-n:删除变量的导出属性。-p:显示全部拥有导出属性的变量。-pf:显示全部拥有导出属性的函数。-nf:删除函数的导出属性。列出当前所有的环境变量>expo

    2022年9月7日
    1
  • python dll注入监听_DLL注入和API拦截

    python dll注入监听_DLL注入和API拦截读《Windows核心编程》笔记一DLL注入和API拦截在Windows中,每个进程相互独立,都有自己的私有的地址空间,程序中使用的指针都是进程自己地址空间的一个内存地址,无法创建也没法使用其他进程的指针。这种机制使得各个进程之间不会相互影响,万一自己出现了问题,也不会影响到其他的进程。对用户来说,系统更加的稳定了,但是对于开发人员来说,会使我们很难编写能够与其他进程通信的应用程序或对其他进程进…

    2022年5月16日
    44
  • pycharm中运行lua脚本requier sys报错_pycharm怎么安装jupyter

    pycharm中运行lua脚本requier sys报错_pycharm怎么安装jupyterpycharm中运行jupyternotebook,首先需要安装:pipinstlljupyternotebook安装完成后在pycharm中新建一个ipynb文件如下图: 然后输入代码,但运行出现了一个问题:解决方法如下:在cmd中运行jupyternotebook,可以看到url和token弄完之后确实可以运行了,但是如果把cmd关掉之后又不能运…

    2022年8月26日
    3
  • 调用wsdl接口 使用xml格式为参数

    调用wsdl接口 使用xml格式为参数

    2020年11月9日
    299
  • FFmepg_ffmpeg下载

    FFmepg_ffmpeg下载FFMpeg0.6版源码下载:来自:http://sourceforge.net/projects/mplayer-win32/files/FFmpeg/FFmpeg-svn-24623.7zffmpeg-r24623.tar.bz2我收集到的相关开发资料:(均来自网络) FFMpeg中apiexample_c例子分析——解码分析.txtffmpeg初级教程.rarff

    2022年9月24日
    0
  • Oracle 时间戳转Date

    Oracle 时间戳转Date当前系统时间向前推一个月selectto_char(add_months(sysdate,-1),’yyyy-mm-ddhh24:mi:ss’)fromdual根据13位毫秒向前推一个月,转换为dateselectto_char(add_months(TO_DATE(TO_CHAR(1564588800000/(1000*60*60*24)+…

    2022年6月29日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号