package com.zfzn.cwyms.message.util;

import java.sql.Timestamp;

import java.util.ArrayList;

import java.util.Calendar;

import java.util.Date;

import java.util.GregorianCalendar;

import java.util.List;

/*

* 因为为了之后使用方便,全部方法的返回类型都设为了 java.util.Date 请在使用时根据本身的须要进行日期格式化处理,如:

*

* import java.text.SimpleDateFormat;SimpleDateFormat simpleDateFormat = new

* SimpleDateFormat("yyyy-MM-dd HH:mm:ss");String todayBegin =

* simpleDateFormat.format

* (DateUtils.getDayBegin());System.out.println(todayBegin );//输出结果为2017-10-26

* 00:00:00

*/

/**

* 1)获取当天的开始时间

* 2)获取当天的结束时间

* 3)获取昨天的开始时间

* 4)获取昨天的结束时间

* 5)获取明天的开始时间

* 6)获取明天的结束时间

* 7)获取本周的开始时间

* 8)获取本周的结束时间

* 9)获取上周的开始时间

* 10)获取上周的结束时间

* 11)获取本月的开始时间

* 12)获取本月的结束时间

* 13)获取上月的开始时间

* 14)获取上月的结束时间

* 15)获取本年的开始时间

* 16)获取本年的结束时间

* 17)获取某个日期的开始时间

* 18)获取某个日期的结束时间

* 19)获取今年是哪一年

* 20)获取本月是哪一月

* 21)两个日期相减获得的天数

* 22)两个日期相减获得的毫秒数

* 23)获取两个日期中的最大日期

* 24)获取两个日期中的最小日期

* 25)返回某月该季度的第一个月

* 26)返回某个日期下几天的日期

* 27)返回某个日期前几天的日期

* 28)获取某年某月到某年某月按天的切片日期集合(间隔天数的集合)

* 29)获取某年某月按天切片日期集合(某个月间隔多少天的日期集合)

*/

/**

* 日期工具类

*/

public class DatesUtil {

// 获取当天的开始时间

public static java.util.Date getDayBegin() {

Calendar cal = new GregorianCalendar();

cal.set(Calendar.HOUR_OF_DAY, 0);

cal.set(Calendar.MINUTE, 0);

cal.set(Calendar.SECOND, 0);

cal.set(Calendar.MILLISECOND, 0);

return cal.getTime();

}

// 获取当天的结束时间

public static java.util.Date getDayEnd() {

Calendar cal = new GregorianCalendar();

cal.set(Calendar.HOUR_OF_DAY, 23);

cal.set(Calendar.MINUTE, 59);

cal.set(Calendar.SECOND, 59);

return cal.getTime();

}

// 获取昨天的开始时间

public static Date getBeginDayOfYesterday() {

Calendar cal = new GregorianCalendar();

cal.setTime(getDayBegin());

cal.add(Calendar.DAY_OF_MONTH, -1);

return cal.getTime();

}

// 获取昨天的结束时间

public static Date getEndDayOfYesterDay() {

Calendar cal = new GregorianCalendar();

cal.setTime(getDayEnd());

cal.add(Calendar.DAY_OF_MONTH, -1);

return cal.getTime();

}

// 获取明天的开始时间

public static Date getBeginDayOfTomorrow() {

Calendar cal = new GregorianCalendar();

cal.setTime(getDayBegin());

cal.add(Calendar.DAY_OF_MONTH, 1);

return cal.getTime();

}

// 获取明天的结束时间

public static Date getEndDayOfTomorrow() {

Calendar cal = new GregorianCalendar();

cal.setTime(getDayEnd());

cal.add(Calendar.DAY_OF_MONTH, 1);

return cal.getTime();

}

// 获取本周的开始时间

@SuppressWarnings("unused")

public static Date getBeginDayOfWeek() {

Date date = new Date();

if (date == null) {

return null;

}

Calendar cal = Calendar.getInstance();

cal.setTime(date);

int dayofweek = cal.get(Calendar.DAY_OF_WEEK);

if (dayofweek == 1) {

dayofweek += 7;

}

cal.add(Calendar.DATE, 2 - dayofweek);

return getDayStartTime(cal.getTime());

}

// 获取本周的结束时间

public static Date getEndDayOfWeek() {

Calendar cal = Calendar.getInstance();

cal.setTime(getBeginDayOfWeek());

cal.add(Calendar.DAY_OF_WEEK, 6);

Date weekEndSta = cal.getTime();

return getDayEndTime(weekEndSta);

}

// 获取上周的开始时间

@SuppressWarnings("unused")

public static Date getBeginDayOfLastWeek() {

Date date = new Date();

if (date == null) {

return null;

}

Calendar cal = Calendar.getInstance();

cal.setTime(date);

int dayofweek = cal.get(Calendar.DAY_OF_WEEK);

if (dayofweek == 1) {

dayofweek += 7;

}

cal.add(Calendar.DATE, 2 - dayofweek - 7);

return getDayStartTime(cal.getTime());

}

// 获取上周的结束时间

public static Date getEndDayOfLastWeek() {

Calendar cal = Calendar.getInstance();

cal.setTime(getBeginDayOfLastWeek());

cal.add(Calendar.DAY_OF_WEEK, 6);

Date weekEndSta = cal.getTime();

return getDayEndTime(weekEndSta);

}

// 获取本月的开始时间

public static Date getBeginDayOfMonth() {

Calendar calendar = Calendar.getInstance();

calendar.set(getNowYear(), getNowMonth() - 1, 1);

return getDayStartTime(calendar.getTime());

}

// 获取本月的结束时间

public static Date getEndDayOfMonth() {

Calendar calendar = Calendar.getInstance();

calendar.set(getNowYear(), getNowMonth() - 1, 1);

int day = calendar.getActualMaximum(5);

calendar.set(getNowYear(), getNowMonth() - 1, day);

return getDayEndTime(calendar.getTime());

}

// 获取上月的开始时间

public static Date getBeginDayOfLastMonth() {

Calendar calendar = Calendar.getInstance();

calendar.set(getNowYear(), getNowMonth() - 2, 1);

return getDayStartTime(calendar.getTime());

}

// 获取上月的结束时间

public static Date getEndDayOfLastMonth() {

Calendar calendar = Calendar.getInstance();

calendar.set(getNowYear(), getNowMonth() - 2, 1);

int day = calendar.getActualMaximum(5);

calendar.set(getNowYear(), getNowMonth() - 2, day);

return getDayEndTime(calendar.getTime());

}

// 获取本年的开始时间

public static Date getBeginDayOfYear() {

Calendar cal = Calendar.getInstance();

cal.set(Calendar.YEAR, getNowYear());

cal.set(Calendar.MONTH, Calendar.JANUARY);

cal.set(Calendar.DATE, 1);

return getDayStartTime(cal.getTime());

}

// 获取本年的结束时间

public static java.util.Date getEndDayOfYear() {

Calendar cal = Calendar.getInstance();

cal.set(Calendar.YEAR, getNowYear());

cal.set(Calendar.MONTH, Calendar.DECEMBER);

cal.set(Calendar.DATE, 31);

return getDayEndTime(cal.getTime());

}

// 获取某个日期的开始时间

public static Timestamp getDayStartTime(Date d) {

Calendar calendar = Calendar.getInstance();

if (null != d)

calendar.setTime(d);

calendar.set(calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH),

calendar.get(Calendar.DAY_OF_MONTH), 0, 0, 0);

calendar.set(Calendar.MILLISECOND, 0);

return new Timestamp(calendar.getTimeInMillis());

}

// 获取某个日期的结束时间

public static Timestamp getDayEndTime(Date d) {

Calendar calendar = Calendar.getInstance();

if (null != d)

calendar.setTime(d);

calendar.set(calendar.get(Calendar.YEAR), calendar.get(Calendar.MONTH),

calendar.get(Calendar.DAY_OF_MONTH), 23, 59, 59);

calendar.set(Calendar.MILLISECOND, 999);

return new Timestamp(calendar.getTimeInMillis());

}

// 获取今年是哪一年

public static Integer getNowYear() {

Date date = new Date();

GregorianCalendar gc = (GregorianCalendar) Calendar.getInstance();

gc.setTime(date);

return Integer.valueOf(gc.get(1));

}

// 获取本月是哪一月

public static int getNowMonth() {

Date date = new Date();

GregorianCalendar gc = (GregorianCalendar) Calendar.getInstance();

gc.setTime(date);

return gc.get(2) + 1;

}

// 两个日期相减获得的天数

public static int getDiffDays(Date beginDate, Date endDate) {

if (beginDate == null || endDate == null) {

throw new IllegalArgumentException("getDiffDays param is null!");

}

long diff = (endDate.getTime() - beginDate.getTime())

/ (1000 * 60 * 60 * 24);

int days = new Long(diff).intValue();

return days;

}

// 两个日期相减获得的毫秒数

public static long dateDiff(Date beginDate, Date endDate) {

long date1ms = beginDate.getTime();

long date2ms = endDate.getTime();

return date2ms - date1ms;

}

// 获取两个日期中的最大日期

public static Date max(Date beginDate, Date endDate) {

if (beginDate == null) {

return endDate;

}

if (endDate == null) {

return beginDate;

}

if (beginDate.after(endDate)) {

return beginDate;

}

return endDate;

}

// 获取两个日期中的最小日期

public static Date min(Date beginDate, Date endDate) {

if (beginDate == null) {

return endDate;

}

if (endDate == null) {

return beginDate;

}

if (beginDate.after(endDate)) {

return endDate;

}

return beginDate;

}

// 返回某月该季度的第一个月

public static Date getFirstSeasonDate(Date date) {

final int[] SEASON = {1, 1, 1, 2, 2, 2, 3, 3, 3, 4, 4, 4};

Calendar cal = Calendar.getInstance();

cal.setTime(date);

int sean = SEASON[cal.get(Calendar.MONTH)];

cal.set(Calendar.MONTH, sean * 3 - 3);

return cal.getTime();

}

// 返回某个日期下几天的日期

public static Date getNextDay(Date date, int i) {

Calendar cal = new GregorianCalendar();

cal.setTime(date);

cal.set(Calendar.DATE, cal.get(Calendar.DATE) + i);

return cal.getTime();

}

// 返回某个日期前几天的日期

public static Date getFrontDay(Date date, int i) {

Calendar cal = new GregorianCalendar();

cal.setTime(date);

cal.set(Calendar.DATE, cal.get(Calendar.DATE) - i);

return cal.getTime();

}

// 获取某年某月到某年某月按天的切片日期集合(间隔天数的集合)

@SuppressWarnings({"rawtypes", "unchecked"})

public static List getTimeList(int beginYear, int beginMonth, int endYear,

int endMonth, int k) {

List list = new ArrayList();

if (beginYear == endYear) {

for (int j = beginMonth; j <= endMonth; j++) {

list.add(getTimeList(beginYear, j, k));

}

} else {

{

for (int j = beginMonth; j < 12; j++) {

list.add(getTimeList(beginYear, j, k));

}

for (int i = beginYear + 1; i < endYear; i++) {

for (int j = 0; j < 12; j++) {

list.add(getTimeList(i, j, k));

}

}

for (int j = 0; j <= endMonth; j++) {

list.add(getTimeList(endYear, j, k));

}

}

}

return list;

}

// 获取某年某月按天切片日期集合(某个月间隔多少天的日期集合)

@SuppressWarnings({"unchecked", "rawtypes"})

public static List getTimeList(int beginYear, int beginMonth, int k) {

List list = new ArrayList();

Calendar begincal = new GregorianCalendar(beginYear, beginMonth, 1);

int max = begincal.getActualMaximum(Calendar.DATE);

for (int i = 1; i < max; i = i + k) {

list.add(begincal.getTime());

begincal.add(Calendar.DATE, k);

}

begincal = new GregorianCalendar(beginYear, beginMonth, max);

list.add(begincal.getTime());

return list;

}

}

这个类的使用方法:

pageinfo对合并list进行分页_Pagehelper不是特别好用。对list直接分页相关推荐

  1. 【Java从0到架构师】MyBatis - 连接池、分页_PageHelper

    连接池.分页 集成 druid 连接池 读取外部的配置文件 分页查询 - PageHelper PageHelper 环境配置 PageHelper 使用方法 Java 从 0 到架构师目录:[Jav ...

  2. jsp mysql 分页插件_知识分享:Mybatis框架如何使用分页插件呢?

    分页插件使用的方式 修改 pom 文件,添加分页 jar 包依赖 修改 mybatis.xml 文件 UserDao 接口,UserMapper.xml 添加对应方法与实现 sql 对应 UserSe ...

  3. PageHelper分页失效问题(通过List流操作和手动分页来解决)

    项目场景: 在公司项目中,成绩查询的业务中有点逻辑在内,需要数据显示两层数据结构和数据筛选和处理,web端需要分页显示,前端展示组件是饿了么UI(Element UI),Java后端接口分页插件使用的 ...

  4. layui分页limit不显示_小心避坑:MySQL分页时使用 limit+order by 会出现数据重复问题...

    20大进阶架构专题每日送达 来源:www.jianshu.com/p/544c319fd838 进入主题前先插一下,当当优惠码福利来一波!当当全场自营图书5折,用优惠码:J2JYFK(长按复制),满2 ...

  5. db2分页查询语句优化_数据量很大,分页查询很慢,该怎么优化?

    点击上方"服务端思维",选择"设为星标" 回复"669"获取独家整理的精选资料集 回复"加群"加入全国服务端高端社群「后 ...

  6. html mvc 分页 保存,Asp.net Mvc3 加载cshtml文件自定义分页+ 查询

    遇到的问题: 单纯的数据列表,分页ok,但是加上其它外界因素,常见的如 查询,排序,分页如何跟它们结合呢? 分页如何和查询,排序结合? 我的思路,查询.排序为主,分页为次. 1.查询条件改变,页码重新 ...

  7. 给DataList分页有两个办法:1、自定义实现分页方法 2、用第三方控件(例如AspNetPager)

    给DataList分页有两个办法:1.自定义实现分页方法 2.用第三方控件(例如AspNetPager) 先介绍下如何自定义实现分页方法. 我的DataList分页方法的核心原理是利用PagedDat ...

  8. mysql 分页查询几种语法_各数据库2种分页语法支持

    Mycat后端通过jdbc接入oracle.db2.sqlserver.postgresql等通过以下2种方式支持分页语法 以防找不到可以先收藏哦! 1 数据库原生分页直接解析 应用端可以通过直接执行 ...

  9. mvc jquery ajax分页实例,jQuery Ajax自定义分页组件(jquery.loehpagerv1.0)实例详解,mvcpagerajax分页...

    jQuery Ajax自定义分页组件(jquery.loehpagerv1.0)实例详解,mvcpagerajax分页 简单的两个步骤即可实现分页功能 //回调里面进行业务处理 function lo ...

最新文章

  1. Pots(poj-3414)bfs+输出路径
  2. VMware Workstation Pro 共享文件夾
  3. 二叉查找树的简单实现
  4. html中前台布局特点,HTML5弹性布局有什么优点
  5. 零拷贝、mmap、sendfile
  6. SpringBoot的AOP是默认开启的,不需要加注解@EnableAspectJAutoProxy____听说SpringAOP 有坑?那就来踩一踩
  7. python下表运算_python科学计算_numpy_广播与下标
  8. r读取文件夹下的所有csv文件_[R语言]读取文件夹下所有子文件夹中的excel文件,并根据分类合并。...
  9. pyinstaller打包总结
  10. Luogu 3423 [POI 2005]BAN-银行票据 (多重背包单调队列优化 + 方案打印)
  11. 【读书笔记《Android游戏编程之从零开始》】9.游戏开发基础(如何快速的进入 Android 游戏开发)
  12. Python 实例教程100例
  13. 【备忘】LAMP兄弟连李明老师讲Linux[更新完毕-共享完毕]
  14. 简易数字电路交通灯设计
  15. 蓄水池采样算法的python实现_蓄水池采样算法-Reservoir Sampling
  16. Pycharm 如何将背景设置成自己喜欢的图片详文
  17. VB.NET MsgBox详解 vs2010
  18. CmakeList中加入OpenCV编译项
  19. 数据扩增python实现
  20. [SWPU2019]伟大的侦探1

热门文章

  1. mailmessage html编码,C#MailMessage顯示HTML標記的AlternateViews
  2. 2019-04-12 cookie基础
  3. 青蛙学Linux—MySQL备份工具XtraBackup
  4. 11月27号例会记录
  5. XIII Open Grodno SU Championship
  6. 基础拾遗------委托详解
  7. MySoft.Data从入门到精通系列(五)【数据更新】
  8. DNN 4.6.2的中文语言包
  9. UA SIE545 优化理论基础9 优先与分治策略1 文件的最优存储顺序
  10. 关于数据存储的那些事1