Java/Linux/Mysql 时区设置

常见时区问题

1. 设置的时候 使用JVM+8区 转换为时间字符串

2. 读取的时候,客户端时区已经变化,但字符串不在变化导致展示问题

3. 发生问题前提:存储了时间字符串,使用事件字符串进行了比对,展示事件字符串

4. 解决方案:使用时间戳,前端根据时间戳进行转换,后端使用UTC时间

Linux 获取时区

# date -R
Tue, 12 Sep 2023 09:41:27 +0800

# date +"%Z %z"
CST +0800

JVM设置时区

启动添加参数:

# 去掉TZ环境变量影响
unset TZ

# TestTimeZone为java类
java -Duser.timezone=Asia/Shanghai TestTimeZone

环境变量设置:

export TZ=Asia/Shanghai

JVM时区参数:

user.timezone 没值则代表取操作系统的默认时区

代码中设置JVM时区

System.setProperty("user.timezone","Asia/Shanghai");

Spring格式化时间类型时区设置

# 配置文件

spring.jackson.time-zone=GMT+8
spring.jackson.date-format=yyyy-MM-dd HH:mm:ss

# 代码上设置

@JsonFormat(timezone = "GMT+8",pattern = "yyyy-MM-dd HH:mm:ss")
private Date createdDate;

代码修改时区

Jvm中默认使用系统的时区

TimeZone timeZone = TimeZone.getDefault();

设置时区为标准时区

TimeZone timeZone = TimeZone.getTimeZone("GMT+8");

获取地区时区:

TimeZone timeZone = TimeZone.getTimeZone("Asia/Shanghai");

使用:

import java.util.TimeZone;

@SpringBootApplication
public class MyApplication {
    public static void main(String[] args) {
        // 设置默认时区为 UTC+8
        TimeZone.setDefault(TimeZone.getTimeZone("UTC+8"));
        SpringApplication.run(MyApplication.class, args);
    }
}

MySQL查询和设置时区

查看时区:

SELECT @@global.time_zone;

设置时区:

在Linux系统下,我们可以在/etc/my.cnf文件中添加如下内容:

[mysqld]
default-time-zone = '+8:00'

SQL中转换时区:

SELECT CONVERT_TZ('2021-07-01 12:00:00', '+00:00', '+08:00');

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

闲猫

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

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

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

打赏作者

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

抵扣说明:

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

余额充值