| | |
| | | public class DateUtil { |
| | | |
| | | public static SimpleDateFormat YYYY_MM_DD_HH_MM_SS=new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); |
| | | public static SimpleDateFormat YYYY_MM_DD_HH_MM=new SimpleDateFormat("yyyy-MM-dd HH:mm"); |
| | | public static SimpleDateFormat YYYY_MM_DD_HH_MM_SS_UNION=new SimpleDateFormat("yyyyMMddHHmmss"); |
| | | public static SimpleDateFormat YYYY_MM_DD=new SimpleDateFormat("yyyy-MM-dd"); |
| | | public static SimpleDateFormat YYYY_MM=new SimpleDateFormat("yyyy-MM"); |
| | | public static SimpleDateFormat YYYY_DOT_MM=new SimpleDateFormat("yyyy.MM"); |
| | | public static SimpleDateFormat YYYY_DOT_MM_DOT_DD=new SimpleDateFormat("yyyy.MM.dd"); |
| | | public static SimpleDateFormat YYYY_MM_TABLE=new SimpleDateFormat("yyyy_MM"); |
| | | |
| | | public static int compare(String date1Str,String date2Str) throws ParseException { |
| | |
| | | * 根据传入的起止时间,按照月切割成不同时间段 |
| | | * @param startTimeStr 2022-11-01 10:00:00 |
| | | * @param endTimeStr 2023-05-01 10:10:10 |
| | | * @return 示例[2022_12,2023_1,2023_2,2023_3,2023_4,2023_5] TODO 这个返回对象格式 需要根据业务需要进行调整 |
| | | * @return 示例[2022_12,2023_1,2023_2,2023_3,2023_4,2023_5] 这个返回对象格式 需要根据业务需要进行调整 |
| | | * 使用方法: |
| | | * 根据返回的第一个数据,如果存在表,则查询筛选条件为>=输入的起始时间;不存在则弃用输入的起始时间 |
| | | * 根据返回的最后个数据,如果表存在,则查询筛选条件为<=输入的终止时间;不存在则弃用输入的终止时间 |
| | |
| | | } |
| | | |
| | | /** |
| | | * 查询使用时,需要处理 默认表查询的问题 倒序 |
| | | * 示例: |
| | | * <p> |
| | | * {2020=[Fri Dec 25 14:12:22 CST 2020, Thu Dec 31 23:59:59 CST 2020]} |
| | | * {2021=[Fri Jan 01 00:00:00 CST 2021, Fri Dec 31 23:59:59 CST 2021]} |
| | | * {2022=[Sat Jan 01 00:00:00 CST 2022, Tue Nov 29 09:12:22 CST 2022]} |
| | | * 或 |
| | | * {2020=[Fri Dec 25 14:12:22 CST 2020, Thu Dec 31 23:59:59 CST 2020]} |
| | | * {2021=[Fri Jan 01 00:00:00 CST 2021, Fri Dec 31 23:59:59 CST 2021]} |
| | | * {2022=[Sat Jan 01 00:00:00 CST 2022, Thu Dec 29 09:12:22 CST 2022]} |
| | | * {default=[Wed Dec 14 15:27:13 CST 2022, Thu Dec 29 09:12:22 CST 2022]} |
| | | * </p> |
| | | * key为数字,表示年度分表;default为默认表 |
| | | * @param startTimeDate 起始时间 |
| | | * @param endTimeDate 终止时间 |
| | | * @return 需要查询的表及查询时间 |
| | | * @throws ParseException |
| | | */ |
| | | public static Map<String,List<Date>> getQueryTimeForSubTablesDescWithOutDefault(Date startTimeDate,Date endTimeDate) throws ParseException { |
| | | //根据筛选的时间段,查询出符合要求的各分表记录数 |
| | | //首先,如果当前时间超过7月,默认表中只有本年度的;如果没超过7月,默认表还存在上一年度的记录 |
| | | Calendar now = Calendar.getInstance(); |
| | | if(endTimeDate.compareTo(now.getTime())>0){ //校验优化最大查询时间 |
| | | endTimeDate = now.getTime(); |
| | | } |
| | | Calendar timeBefore7Month = Calendar.getInstance(); |
| | | timeBefore7Month.add(Calendar.MONTH,-7); |
| | | |
| | | LinkedHashMap<String,List<Date>> yearTimeMap = (LinkedHashMap<String, List<Date>>) DateUtil.getYearListDesc(startTimeDate, endTimeDate); |
| | | return yearTimeMap; |
| | | } |
| | | |
| | | /** |
| | | * 按年划分 |
| | | * 优化getQueryTimeForSubTablesDesc,待测试 |
| | | * 更新default表是否查询的逻辑,改||为&& |
| | |
| | | return yearTimeDescMap; |
| | | } |
| | | |
| | | /** |
| | | * 按月划分且,不存在默认表,都是分表 |
| | | * @param startTimeDate |
| | | * @param endTimeDate |
| | | * @return |
| | | * @throws ParseException |
| | | */ |
| | | public static Map<String,List<Date>> getQueryTimeForSubTablesByMonthDesc2(Date startTimeDate,Date endTimeDate) throws ParseException { |
| | | //根据筛选的时间段,查询出符合要求的各分表记录数 |
| | | //首先,如果当前时间超过7月,默认表中只有本年度的;如果没超过7月,默认表还存在上一年度的记录 |
| | | Calendar now = Calendar.getInstance(); |
| | | if(endTimeDate.compareTo(now.getTime())>0){ //校验优化最大查询时间 |
| | | endTimeDate = now.getTime(); |
| | | } |
| | | LinkedHashMap<String,List<Date>> yearTimeMap = (LinkedHashMap<String, List<Date>>) DateUtil.getMonthListDesc(startTimeDate, endTimeDate); |
| | | Map<String,List<Date>> yearTimeDescMap = new LinkedHashMap<>(); |
| | | boolean existDefaultYear = false; |
| | | //查询的结束时间 |
| | | //if(DateUtil.YYYY_MM_TABLE.format(endTimeDate).equals(DateUtil.YYYY_MM_TABLE.format(now.getTime()))){ |
| | | if(ThreadLocalUtil.format(endTimeDate,2).equals(ThreadLocalUtil.format(now.getTime(),2))){ |
| | | List<Date> defaultDateList = new LinkedList<>(); |
| | | defaultDateList.add(startTimeDate); |
| | | defaultDateList.add(endTimeDate); |
| | | } |
| | | //调整下顺序,将default调整到首位 |
| | | if(existDefaultYear){ |
| | | List<Date> defaultTimeList = yearTimeMap.get("default"); |
| | | yearTimeDescMap.put("default",defaultTimeList); |
| | | } |
| | | Set<String> yearSet = yearTimeMap.keySet(); |
| | | for (String year : yearSet) { |
| | | if(!year.equals("default")){ |
| | | yearTimeDescMap.put(year,yearTimeMap.get(year)); |
| | | } |
| | | } |
| | | |
| | | return yearTimeDescMap; |
| | | } |
| | | |
| | | |
| | | public static void main(String[] args) throws ParseException { |
| | | //Date d1 = YYYY_MM_DD_HH_MM_SS.parse("2023-01-22 14:12:22"); |