首页 技术 正文
技术 2022年11月15日
0 收藏 597 点赞 2,281 浏览 1635 个字

最近写了一个支付宝微信对账报表,发现系统金额比支付宝微信的少好多,左查右查发现是追缴金额没统计到,再一查发现月结束日期为2019-09-31,9月咋会有31,为啥呢就追缴金额不行呢,因为其他类型用TIMESTAMP即使9.31不对也能统计到,而追缴用的时间戳存为int值,UNIX_TIMESTAMP(‘2019-09-31 23:59:59’)转换为0.000000导致结束时间不对where条件查询就有问题。

在仔细一查发现工具类中有一个获取月份最大值,问题就出现在这里咯。代码很简单

    public static int LastDay(int month) {
Calendar calendar = Calendar.getInstance(); //获取当前时间
calendar.set(Calendar.MONTH, month-1); //设置月份
int maxday =calendar.getActualMaximum(Calendar.DAY_OF_MONTH); //获取最大值
return maxday;
}

然后我发现无论传什么进去最大值都是31。

在System.out.println(calendar.getTime());打印出当前时间看看。发现如果传进去的月份有31号,那么就打印当月31号,如果没有31号就为下个月的1号。输入二月时输出为3号。

输入二月份debug一下,

Calendar.getInstance()值为2019-10-31如下图

Calendar类set方法中的坑

calendar.set(Calendar.MONTH, 2-1)设置为二月如下图,发现DAY_OF_MONTH=31,依然为31号

Calendar类set方法中的坑

System.out.println(calendar.getTime())一下,输出为2019-03-03,2019-02-31转为2019-03-03

Calendar类set方法中的坑

calendar.getActualMaximum(Calendar.DAY_OF_MONTH)输出值为31,由此可见,不能只设置月份,要整个clear掉,重新设置年月,这样才会根据月份取最大值,不然会取到DAY_OF_MONTH的值。

解决方案一:

    /**
* 获取某年某月的日期最大值
* @param year 年份
* @param month 月份
* @return 最大值
*/
public static int LastDay(int year , int month) {
Calendar calendar = Calendar.getInstance();
calendar.clear(); //清除所有日期数据
if (year != 0 ) {
calendar.set(Calendar.YEAR, year);
}
calendar.set(Calendar.MONTH, month-1);
int maxday =calendar.getActualMaximum(Calendar.DAY_OF_MONTH);
return maxday;
}

解决方案二:

    /**
* 根据年月获取当月最后一天
* @param yearmonth yyyy-MM
* @return yyyy-MM-dd
* @throws ParseException
*/
public static String getLastDayOfMonth(String yearmonth) {
try {
SimpleDateFormat format = new SimpleDateFormat("yyyy-MM");
Date dd = format.parse(yearmonth);
Calendar cal = Calendar.getInstance();
cal.setTime(dd);
int cc=cal.getActualMaximum(Calendar.DAY_OF_MONTH);
String result = yearmonth+"-"+cc;
return result;
} catch (ParseException e) {
e.printStackTrace();
}
return null;
}
相关推荐
python开发_常用的python模块及安装方法
adodb:我们领导推荐的数据库连接组件bsddb3:BerkeleyDB的连接组件Cheetah-1.0:我比较喜欢这个版本的cheeta…
日期:2022-11-24 点赞:878 阅读:8,996
Educational Codeforces Round 11 C. Hard Process 二分
C. Hard Process题目连接:http://www.codeforces.com/contest/660/problem/CDes…
日期:2022-11-24 点赞:807 阅读:5,510
下载Ubuntn 17.04 内核源代码
zengkefu@server1:/usr/src$ uname -aLinux server1 4.10.0-19-generic #21…
日期:2022-11-24 点赞:569 阅读:6,353
可用Active Desktop Calendar V7.86 注册码序列号
可用Active Desktop Calendar V7.86 注册码序列号Name: www.greendown.cn Code: &nb…
日期:2022-11-24 点赞:733 阅读:6,137
Android调用系统相机、自定义相机、处理大图片
Android调用系统相机和自定义相机实例本博文主要是介绍了android上使用相机进行拍照并显示的两种方式,并且由于涉及到要把拍到的照片显…
日期:2022-11-24 点赞:512 阅读:7,770
Struts的使用
一、Struts2的获取  Struts的官方网站为:http://struts.apache.org/  下载完Struts2的jar包,…
日期:2022-11-24 点赞:671 阅读:4,848