时间格式化转换及时间比较compareTo

发布时间 2023-12-04 22:33:52作者: oktokeep

时间格式化转换及时间比较compareTo

/**
* 时间格式的转换:在具体报错的地方做转换,可能不能从根本上面解决问题。不排除在其他的代码位置也会使用该错误格式的数据。
*
* 1.可以将数据源的数据批量格式化 yyyy-MM-dd (错误格式:yyyy-MM-dd 00:00:00)
* update tbl_test set ext1 = left(ext1,10) where RIGHT(`ext1`,8) = '00:00:00' and `create_date` >= '2022-10-01 00:00:00'
*
* ## 没有数据需要二次处理,查询需要批量更新的数据
* select * from tbl_test where RIGHT(`ext1`,8) = '00:00:00' and `create_date` >= '2022-10-01 00:00:00'
*
* 2.从源头接口入参的方法处 做错误格式的参数 做兼容处理。按统一的格式来作为入参。
*/

 

A,compareTo(B)

//compareTo 大于 = 1     A>B
//compareTo 小于 = -1   A < B
//compareTo 等于 = 0    A = B

package com.example.core.mydemo.date;

import java.time.LocalDate;
import java.time.LocalDateTime;
import java.time.format.DateTimeFormatter;

public class DateTime2Test {

    public static final DateTimeFormatter DF2 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss");
    public static final DateTimeFormatter DF22 = DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm");

    public static void main(String[] args) {
        String ss = "2023-11-26 21:00:15";
        System.out.println("ss=" + ss);

        ss = "2023-11-26 21:00";

        /**
         * 时间格式的转换:在具体报错的地方做转换,可能不能从根本上面解决问题。不排除在其他的代码位置也会使用该错误格式的数据。
         *
         * 1.可以将数据源的数据批量格式化 yyyy-MM-dd
         * update tbl_test set ext1 = left(ext1,10) where RIGHT(`ext1`,8)  = '00:00:00' and `create_date` >= '2022-10-01 00:00:00'
         *
         * ## 没有数据需要二次处理
         * select * from tbl_test where RIGHT(`ext1`,8)  = '00:00:00' and `create_date` >= '2022-10-01 00:00:00'
         *
         * 2.从源头接口入参的方法处 做错误格式的参数 做兼容处理。
         */
        if(ss.length() == 16){
            ss = ss + ":00";
        }
        LocalDateTime rentDateTime = LocalDateTime.parse(ss, DF2);
        System.out.println("rentDateTime=" + rentDateTime);


        DateTimeFormatter YYYYMMDD_FORMATTER = DateTimeFormatter.ofPattern("yyyyMMdd");
        String dateTimeStr = LocalDate.now().format(YYYYMMDD_FORMATTER);
        StringBuffer buffer = new StringBuffer(dateTimeStr);
        buffer.append("080000");
        Long dateTime = Long.valueOf(buffer.toString());
        System.out.println("dateTime=" + dateTime);

//        Long revertTime = 20231130140000L;
        Long revertTime = 20231204080000L;

        //compareTo  大于 = 1
        //compareTo  小于 = -1
        //compareTo  等于 = 0
        System.out.println("compareTo = " + dateTime.compareTo(revertTime));

        //找出revertTime大于当前时间的,标识为“符合”
        if (dateTime.compareTo(revertTime) == 1 || dateTime.compareTo(revertTime) == 0) {
            System.out.println("不符合");
        }else{
            System.out.println("符合");
        }

    }
}