【时区】一些我搞不懂的时区说明和工具类

文章介绍了UTC与GMT的关系,指出UTC作为世界标准时间的准确性,并讨论了时区划分、UNIX时间戳的概念以及在Java中处理日期和时间的示例,包括线程安全的日期格式转换和获取默认时区的方法。

GMT和UTC

GMT,即格林尼治标准时间,也就是世界时。GMT的正午是指当太阳横穿格林尼治子午线(本初子午线)时的时间。但由于地球自转不均匀不规则,导致GMT不精确,现在已经不再作为世界标准时间使用。

UTC,即协调世界时。UTC是以原子时秒长为基础,在时刻上尽量接近于GMT的一种时间计量系统。为确保UTC与GMT相差不会超过0.9秒,在有需要的情况下会在UTC内加上正或负闰秒。UTC现在作为世界标准时间使用。

所以,UTC与GMT基本上等同,误差不超过0.9秒。

时区

地球自西向东旋转,东边比西边先看到太阳,东边的时间也比西边的早。为了统一世界的时间,1884年的国际经度会议规规定将全球划分为24个时区(东、西各12个时区)。规定英国(格林尼治天文台旧址)为零时区(GMT+00),东1-12区,西1-12区,中国北京处于东8区(GMT+08)。

若英国时间为6点整,则GMT时间为6点整,则北京时间为14点整。

UNIX时间戳

计算机中的UNIX时间戳,是以GMT/UTC时间「1970-01-01T00:00:00」为起点,到具体时间的秒数,不考虑闰秒。这么做当然是为了简化计算机对时间操作的复杂度。

比如我的电脑现在的系统时间为2015年2月27日15点43分0秒,因为我的电脑默认时区为东8区,则0时区的时间为2015年2月27日7点43分0秒,则UNIX时间戳为1425022980秒。

时间中的T

那个T 是 UTC时间

java中形如yyyy-MM-dd’T’HH:mm:ss.SSSZ 转化成各种格式的问题

Z代表0时区,北京时间差8小时

string类型时间转换成date(线程安全)

public static Date parseSync8(String dateStr, String pattern) {
    if (StringUtils.isEmpty(pattern)) {
        pattern = DATE_PATTERN;
    }
    java.time.format.DateTimeFormatter formatter =   java.time.format.DateTimeFormatter.ofPattern(pattern);
    java.time.LocalDateTime date = java.time.LocalDateTime.parse(dateStr, formatter);
    ZoneId zoneId = ZoneId.systemDefault();
    ZonedDateTime zdt = date.atZone(zoneId);
    return Date.from(zdt.toInstant());
}

date类型时间转换成string(线程安全)

public static String formatSync8(Date date, String pattern) {
    if (StringUtils.isEmpty(pattern)) {
        pattern = DATE_PATTERN;
    }
    java.time.format.DateTimeFormatter formatter = java.time.format.DateTimeFormatter.ofPattern(pattern);
    ZoneId zoneId = ZoneId.systemDefault();
    LocalDateTime now = date.toInstant().atZone(zoneId).toLocalDateTime();
    return now.format(formatter);
}

获取默认时区

public static ZoneOffset getZone(){
    return OffsetDateTime.now().getOffset();
}

参考资料

1、代码

https://zhuanlan.zhihu.com/p/149302250

<think>好的,用户现在说“有点不容易懂啊”,我需要分析他们的需求。之前的回答是关于Struts2连接数据库的详细步骤,可能用户觉得内容太多或者太复杂了。用户可能是刚开始学习Java Web开发,或者对Struts2数据库连接不太熟悉。 首先,用户可能对技术术语不太理解,比如Maven依赖、驱动配置、连接池等。他们可能需要更简化的步骤,或者更基础的解释。其次,用户可能在操作过程中遇到了问题,比如配置文件的位置不对,或者代码有错误导致无法连接数据库,但不知道具体哪里出错了。另外,用户可能希望有更多的示例代码或者截图,特别是中文界面下的IDE操作,比如如何在IDEA中添加数据库驱动,配置数据源等。 接下来,我需要调整之前的回答,使其更易于理解。可能需要分步骤讲解,每一步都解释清楚为什么要这么做,以及注意事项。例如,在添加数据库驱动时,解释Maven依赖的作用,或者手动添加jar包的具体位置。对于配置文件,可能需要详细说明每个参数的含义,比如jdbc.url中的时区设置为什么重要。 另外,用户提到的中文错误处理部分,可能需要更直观的错误信息对应解决方案,比如将错误信息加粗或者用更醒目的方式标出。同时,可以补充一些常见问题的排查步骤,比如检查网络连接、数据库服务是否启动等。 在进阶方案部分,用户可能暂时不需要连接池的内容,但可以简要说明使用连接池的好处,让用户了解后续优化的方向。在典型使用场景中,可能需要更详细的代码注释,解释每个步骤的作用,比如为什么要在Action中调用DBUtil,如何处理结果集等。 最后,用户可能需要更多的鼓励提示,比如建议分阶段学习,先完成基础连接,再逐步学习优化措施。同时,提醒用户遇到具体错误时提供详细信息,以便更准确地解决问题。</think>我理解刚开始接触可能会觉得步骤较多,这里帮你拆解成更简单的操作流程(含示意图说明): --- ### **极简三步法**(适合第一次连接) #### **第一步:放驱动文件**(就像给电脑装打印机驱动) 1. 下载 [mysql-connector-java-8.x.jar](https://dev.mysql.com/downloads/connector/j/) 2. 复制到项目的 `WEB-INF/lib` 文件夹(没有就新建) ``` 你的项目 └── web └── WEB-INF └── lib └── mysql-connector-java-8.0.33.jar ✅ ``` #### **第二步:写配置文件**(类似填写账号密码) 1. 在 `src/main/resources` 新建 `db.properties` 2. 内容如下(直接替换你的真实信息): ```properties jdbc.url=jdbc:mysql://localhost:3306/你的数据库名?useUnicode=true&characterEncoding=UTF-8 jdbc.username=root jdbc.password=123456 ``` #### **第三步:复制工具类**(直接使用现成代码) ```java // 在项目中新建 DBUtil.java public class DBUtil { public static Connection getConnection() throws Exception { Class.forName("com.mysql.cj.jdbc.Driver"); return DriverManager.getConnection( "jdbc:mysql://localhost:3306/你的数据库名", "root", "123456" ); } } ``` --- ### **可视化检查点**(避免常见错误) | 检查项 | 正确示例 | 错误示例 | |---------|---------|---------| | **驱动文件位置** | ![正确位置截图](https://via.placeholder.com/200x100?text=WEB-INF/lib/jar文件存在) | 放在src/main目录下 ❌ | | **数据库服务状态** | ![MySQL运行截图](https://via.placeholder.com/200x100?text=MySQL服务已启动) | 忘记启动MySQL服务 ❌ | | **连接代码测试** | ![测试成功截图](https://via.placeholder.com/200x100?text=Connection+Success) | 端口写错成8080 ❌ | --- ### **分步测试建议** 1. 先用Navicat/DBeaver等工具图形化连接数据库(确认网络可达) 2. 单独运行这个测试代码: ```java public class TestConnection { public static void main(String[] args) { try { Connection conn = DBUtil.getConnection(); System.out.println("🌟连接成功!"); conn.close(); } catch (Exception e) { System.out.println("❌连接失败:" + e.getMessage()); } } } ``` --- ### **典型问题速查表** ```text 问题现象 解决方案 ----------------------------------------------------------- 提示"没有驱动" 检查WEB-INF/lib是否有驱动jar包 密码正确但拒绝访问 检查数据库用户
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

木有会

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

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

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

打赏作者

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

抵扣说明:

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

余额充值