前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >时间格式化转换及时间比较compareTo,Controller层接收参数格式化,从数据源头解决时间格式错误数据对接口的影响

时间格式化转换及时间比较compareTo,Controller层接收参数格式化,从数据源头解决时间格式错误数据对接口的影响

作者头像
oktokeep
发布2024-10-09 11:06:01
发布2024-10-09 11:06:01
10800
代码可运行
举报
文章被收录于专栏:第三方工具
运行总次数:0
代码可运行

时间格式化转换及时间比较compareTo,Controller层接收参数格式化,从数据源头解决时间格式错误数据对接口的影响

/** * 时间格式的转换:在具体报错的地方做转换,可能不能从根本上面解决问题。不排除在其他的代码位置也会使用该错误格式的数据。 * * 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

代码语言:javascript
代码运行次数:0
复制
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("符合");
        }

    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-12-04,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档