java 两个日期时间段,以每晚0点0分0秒分割成多个时间段。

日期区间拆分
本文介绍了一个用于解决第三方接口跨天查询限制的方法,通过将日期区间拆分为以天为单位的多个段落,使得每次查询都能在同一天内完成。文章提供了具体的Java实现代码,包括计算两个日期之间的天数差、获取一天的开始和结束时间。

在公司页面中需要掉一个第三方的接口,然后他们的接口不能跨天查询,网上也没搜到,索性自己写一个,写的不好,请多关照反正能用。

/**
     * 把时间段拆分成以天为区分
     *
     * @param d1
     * @param d2
     * @return
     */
    public static List<Map<String, Object>> getDateDifference(Date d1, Date d2) {
    	// 获取两天间隔多少天,如果间隔大于一天计算,否则就返回当前时间
        int days = differentDays(d1, d2);
        List<Map<String, Object>> dateList = new ArrayList<>();
        if (days > 0) {
            for (int i = 0; i <= days; i++) {
                Map<String, Object> dateMap = new HashMap<>();
                Calendar calendar = Calendar.getInstance();
                calendar.setTime(d1);
                calendar.add(Calendar.DATE, i);
                Date d = calendar.getTime();
                // 获取一天最开始的时间
                dateMap.put("liveStartTime", getDayStart(d));
                // 获取一天结束的时间
                dateMap.put("liveEndTime", getDayEnd(d));
                dateList.add(dateMap);
            }
        } else {
            Map<String, Object> dateMap = new HashMap<>();
            dateMap.put("liveStartTime", getDayStart(d1));
            dateMap.put("liveEndTime", getDayEnd(d2));
            dateList.add(dateMap);
        }
        return dateList;
    }
/**
     * date2比date1多的天数
     *
     * @param date1
     * @param date2
     * @return
     */
    public static int differentDays(Date date1, Date date2) {
        Calendar cal1 = Calendar.getInstance();
        cal1.setTime(date1);

        Calendar cal2 = Calendar.getInstance();
        cal2.setTime(date2);
        int day1 = cal1.get(Calendar.DAY_OF_YEAR);
        int day2 = cal2.get(Calendar.DAY_OF_YEAR);

        int year1 = cal1.get(Calendar.YEAR);
        int year2 = cal2.get(Calendar.YEAR);
        if (year1 != year2) //同一年
        {
            int timeDistance = 0;
            for (int i = year1; i < year2; i++) {
                if (i % 4 == 0 && i % 100 != 0 || i % 400 == 0) //闰年
                {
                    timeDistance += 366;
                } else //不是闰年
                {
                    timeDistance += 365;
                }
            }

            return (timeDistance + (day2 - day1) + 1);
        } else //不同年
        {
            System.out.println("判断day2 - day1 : " + (day2 - day1));
            return (day2 - day1);
        }
    }
/**
     * 获取一天最开始的时间
     *
     * @param date
     * @return
     */
    public static Date getDayStart(Date date) {
        Calendar calendar = Calendar.getInstance();
        calendar.setTime(date);
        //设置每天的最小小时
        calendar.set(Calendar.HOUR_OF_DAY, calendar.getActualMinimum(Calendar.HOUR_OF_DAY));
        //设置每小时最小分钟
        calendar.set(Calendar.MINUTE, calendar.getActualMinimum(Calendar.MINUTE));
        //设置每分钟最小秒
        calendar.set(Calendar.SECOND, calendar.getActualMinimum(Calendar.SECOND));
        return calendar.getTime();
    }
/**
     * 获取一天结束的时间
     *
     * @param date
     * @return
     */
    public static Date getDayEnd(Date date) {
        Calendar calendar = Calendar.getInstance();
        calendar.setTime(date);
        //设置每天的最小小时
        calendar.set(Calendar.HOUR_OF_DAY, calendar.getActualMaximum(Calendar.HOUR_OF_DAY));
        //设置每小时最大分钟
        calendar.set(Calendar.MINUTE, calendar.getActualMaximum(Calendar.MINUTE));
        //设置每分钟最大秒
        calendar.set(Calendar.SECOND, calendar.getActualMaximum(Calendar.SECOND));
        return calendar.getTime();
    }
Java中,你可以使用`java.util.Timer`或更现代的`java.time`和`ScheduledExecutorService`来创建一个定时任务,结合JDBC(Java Database Connectivity)来执行数据库备份。以下是一个基本的示例,使用`ScheduledExecutorService`,因为它提供了更多的灵活性和控制。 ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.PreparedStatement; import java.sql.SQLException; import java.time.LocalDateTime; import java.time.ZoneId; import java.time.format.DateTimeFormatter; import javax.sql.DataSource; public class BackupTask implements Runnable { private static final String BACKUP_QUERY = "INSERT INTO backup_table SELECT * FROM main_table"; private DataSource dataSource; public BackupTask(DataSource dataSource) { this.dataSource = dataSource; } @Override public void run() { try { // 获取当前时间并转换为指定时区(例如UTC) LocalDateTime currentDateTime = LocalDateTime.now().atZone(ZoneId.of("UTC")); DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyy-MM-dd_HH-mm"); String backupFileName = "backup_" + currentDateTime.format(formatter) + ".sql"; // 连接到数据库 Connection conn = dataSource.getConnection(); PreparedStatement stmt = conn.prepareStatement(BACKUP_QUERY); // 执行备份查询 stmt.executeUpdate(); // 关闭连接 stmt.close(); conn.close(); System.out.println("Backup completed for time: " + backupFileName); } catch (SQLException e) { System.err.println("Error during backup: " + e.getMessage()); } } public static void main(String[] args) { // 创建一个基于文件系统的数据源 // 注意替换实际的URL、用户名和密码 String url = "jdbc:dmdb://localhost:1521/mydatabase"; String username = "your_username"; String password = "your_password"; try { DataSource dataSource = DriverManager.getConnection(url, username, password)..unwrap(DataSource.class); // 使用ScheduledExecutorService来调度任务每晚12执行 ScheduledExecutorService executor = Executors.newSingleThreadScheduledExecutor(); executor.scheduleAtFixedRate(new BackupTask(dataSource), 0, 1, TimeUnit.DAYS); // 每天午夜12执行 executor.shutdown(); // 不关闭,否则会在第一次执行后立即停止 System.out.println("Backup task scheduled. Press Ctrl+C to stop."); } catch (SQLException | InterruptedException e) { e.printStackTrace(); } } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值