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)));
// }

}

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • c语言字符数组初始化的三种方式_c语言赋值字符串

    c语言字符数组初始化的三种方式_c语言赋值字符串C语言中字符数组的初始化与赋值,字符串相关函数!1.字符数组初始化在C语言中,字符串是当做字符数组来处理的;所以字符串有两种声明方式,一种是字符数组,一种是字符指针。(1)直接逐个初始化字符数组:字符数组的初始化,最容易理解的方式就是逐个字符赋给数组中各元素。charstr[10]={‘I’,”,’a’,’m’,”,‘h’,’a’,’p’,’p’…

  • 重定向和转发区别[通俗易懂]

    重定向和转发区别[通俗易懂]一、转发转发的原理,可以通过下图展示:浏览器的请求发送给组件1,组件1经过一些处理之后,将request和response对象“传递”给组件2,由组件2继续处理,然后输出响应(当然,也可以继续向其他组件“传递”),这个传递的过程称之为“转发”。整个过程只涉及一次浏览器和服务器之间的“请求-响应”,转发过程中的组件共享同一个请求(request)和响应(response)对象。转发的意义在于可以实现组件的**“分工”。**在基于MVC,多层结构的Web应用中,经常需要多个组件协同完成一次“请求

  • 操作系统实验一进程管理实验报告(进程的管理和控制实验报告)

    实验一进程管理1.目的和要求通过实验理解进程的概念,进程的组成(PCB结构),进程的并发执行和操作系统进行进程管理的相关原语(主要是进程的创建、执行、撤消)。2.实验内容用C语言编程模拟进程管理,至少要有:创建新的进程;查看运行进程;换出某个进程;杀死运行进程以及进程之间通信等功能。3.实验环境Windows操作系统、VC++6.0C语言4.实验提示PCB结…

  • activity启动FLAG之FLAG_ACTIVITY_CLEAR_TASK「建议收藏」

    activity启动FLAG之FLAG_ACTIVITY_CLEAR_TASK「建议收藏」随时随地阅读更多技术实战干货,获取项目源码、学习资料,请关注源代码社区公众号(ydmsq666)官方文档解释:IfsetinanIntentpassedtoContext.startActivity(),thisflagwillcauseanyexistingtaskthat…

  • SQLServer2008安装教程[通俗易懂]

    SQLServer2008安装教程[通俗易懂]因为对接老系统的数据,上面使用的SQLServer2008,所以本机也需要SQLServer2008作对接。首当其冲的就是SQLServer2008的安装。1.下载sqlServer2008的安装包2.在安装包中点击setup.exe2.选择安装,再选择全新安装3.安装规则检测,等待通过后确认4.产品密钥会自动填充直接下一步(不截图说明)5.勾选“我接受”直接下一步(不截图说明)6.对于程序支持文件,点击安装;然后安装通过,点击下一步7.设置角色,选择“功..

  • 集合遍历中删除行不行「建议收藏」

    集合遍历中删除行不行「建议收藏」集合遍历中删除行不行

发表回复

您的电子邮箱地址不会被公开。

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