【坑】MySQL数据库对于毫秒大于500的数据会进位

在做数据统计报表发现跨天的时候发现数据会丢失一部分,后来发现23:59:59插入到数据库中,总是多一秒



public static void main(String[] args) {
        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR_OF_DAY, 23);
        calendar.set(Calendar.MINUTE, 59);
        calendar.set(Calendar.SECOND, 59);
        System.out.println(calendar.getTime().getTime());
 }

在这里插入图片描述

如果calendar对象不设置毫秒数值,生成的时间对象毫秒数值是随机的,保存到数据库时,MySQL会对毫秒大于500的数据进行进位,所以出现了+1秒的情况

/**
     * Obtains an instance of {@code LocalTime} from an hour, minute, second and nanosecond.
     * <p>
     * This returns a {@code LocalTime} with the specified hour, minute, second and nanosecond.
     *
     * @param hour  the hour-of-day to represent, from 0 to 23
     * @param minute  the minute-of-hour to represent, from 0 to 59
     * @param second  the second-of-minute to represent, from 0 to 59
     * @param nanoOfSecond  the nano-of-second to represent, from 0 to 999,999,999
     * @return the local time, not null
     * @throws DateTimeException if the value of any field is out of range
     */
    public static LocalTime of(int hour, int minute, int second, int nanoOfSecond) {
        HOUR_OF_DAY.checkValidValue(hour);
        MINUTE_OF_HOUR.checkValidValue(minute);
        SECOND_OF_MINUTE.checkValidValue(second);
        NANO_OF_SECOND.checkValidValue(nanoOfSecond);
        return create(hour, minute, second, nanoOfSecond);
    }
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL单表数据大于500万时,需要考虑以下几个方面: 1. 数据库的选型:MySQL是一个开源的关系型数据库管理系统,可以应对大部分的数据存储需求。但是当单表数据超过500万时,需要评估MySQL是否仍然能够满足性能需求,是否需要考虑其他高性能数据库或者分布式数据库方案。 2. 数据库表的设计:优化数据库表结构是提高性能的基础。可以考虑使用合适的数据类型和字段长度来节省存储空间,对经常查询的字段添加索引,避免使用过多的关联关系等。 3. 数据库索引的优化:合理的索引可以加速查询操作。在单表数据量大的情况下,需要根据实际查询需求,添加合适的索引。注意维护索引的代价和空间占用。 4. 数据分区:当单表数据超过500万时,可以考虑将数据进行分区存储。根据数据的特性,可以按照日期、地理位置、用户等进行分区。分区可以提高查询性能,降低数据的维护成本。 5. 数据库服务器的优化:对数据库服务器进行性能优化可以有效提高查询性能。可以考虑调整数据库的缓存设置、线程池大小、网络连接数等参数,以及与硬件资源配套的优化等。 6. 数据备份和容灾:当单表数据量大时,数据备份和容灾变得尤为重要。需要定期进行数据备份,确保数据的安全性。同时可考虑使用数据库复制或者分布式数据库方案来实现高可用和故障恢复。 总之,当MySQL单表数据大于500万时,需要综合考虑数据库的选型、表结构设计、索引优化、数据分区、服务器优化、数据备份和容灾等方面,以提高查询性能和数据安全性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值