Java默认util.Date时间插入mysql数据差1天|差8小时|时区不同

不修改数据库设置
不修改Jdbc连接数据库设置。
注意:我的例子当中时间精确到天即可,只要天数正确就算正常,其他情况未测试。

1.查看数据库时间是否正确。

select now();

数据库默认时间是否正确

2.查看mysql系统时区。

show variables like '%time_zone%';

查看数据库默认时区

3.将Java代码的Date时区设置为默认数据库时区。

function:将一个(“yyyy-MM-dd”)日期字符串转换为Java.util.Date()类型。

    public Date strToDate(String strDate) {
        SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd");
        ParsePosition pos = new ParsePosition(0);
        formatter.setTimeZone(TimeZone.getTimeZone("CST"));/*我的数据库默认是CST时区*/
        Date date = formatter.parse(strDate, pos);
        return date ;
    }

4.用mybatis逆向工程从数据库查询的timestamp时间相差13小时

前置条件
从timestamp转换为JavaDate相差13个小时。

将数据库url添加 serverTimezone=Asia/Shanghai

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

万物皆可撸

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值