time zone

mysql global time zone = UTC

前端调用java程序入参如下:

{
    "dateTime":"2020-07-01 9:07:04",
    "timeStamp":"2020-07-01 9:07:04"
}
url: jdbc:mysql://122.51.245.236:3306/z?useSSL=false&useUnicode=true&characterEncoding=utf-8&useLegacyDatetimeCode=false&serverTimezone=UTC

会话以UTC时区,查看 新插入数据如下
khkhkkhkh

url: jdbc:mysql://122.51.245.236:3306/z?useSSL=false&useUnicode=true&characterEncoding=utf-8&useLegacyDatetimeCode=false&serverTimezone=Asia/Tokyo

会话以UTC时区,查看 新插入数据如
在这里插入图片描述

url: jdbc:mysql://122.51.245.236:3306/z?useSSL=false&useUnicode=true&characterEncoding=utf-8&useLegacyDatetimeCode=false&serverTimezone=Asia/Shanghai

会话以UTC时区,查看 新插入数据如
在这里插入图片描述

会话以Asia/Shanghai时区,查看 新插入数据如

set time_zone = '+8:00';
show variables like '%time_zone%'
select * from _time;

在这里插入图片描述
datetime 与timestamp区别:

  • datetime类型,java传入的是什么时间数据库存的就是什么时间,和时区没有关系
  • timestamp类型,和时区有关系。简单理解:这个值是用两个字段共同标识出来的
  1. mysql default timezone + date
  2. java存取数据时,返回给java的date值是在默认时区下对应的date值
  3. time_stamp 只支持到2038年,这个有很大的局限性

serverTimezone可选值列举:

<?xml version="1.0" encoding="UTF-8"?>
<timezones>
	<timezone id="Asia/Shanghai">中国标准时间 (北京)</timezone>
	<timezone id="Asia/Hong_Kong">香港时间 (香港)</timezone>
	<timezone id="Asia/Taipei">台北时间 (台北)</timezone>
	<timezone id="Asia/Seoul">首尔</timezone>
	<timezone id="Asia/Tokyo">日本时间 (东京)</timezone>
	<timezone id="America/New_York">美国东部时间 (纽约)</timezone>
	<timezone id="America/Denver">美国山区时间 (丹佛)</timezone>
	<timezone id="America/Costa_Rica">美国中部时间 (哥斯达黎加)</timezone>
    <timezone id="America/Chicago">美国中部时间 (芝加哥)</timezone>
    <timezone id="America/Mexico_City">美国中部时间 (墨西哥城)</timezone>
    <timezone id="America/Regina">美国中部时间 (里贾纳)</timezone>
    <timezone id="America/Los_Angeles">美国太平洋时间 (洛杉矶)</timezone>
    <timezone id="Pacific/Majuro">马朱罗</timezone>
    <timezone id="Pacific/Midway">中途岛</timezone>
    <timezone id="Pacific/Honolulu">檀香山</timezone>
    <timezone id="America/Anchorage">安克雷奇</timezone>
    <timezone id="America/Tijuana">美国太平洋时间 (提华纳)</timezone>
    <timezone id="America/Phoenix">美国山区时间 (凤凰城)</timezone>
    <timezone id="America/Chihuahua">奇瓦瓦</timezone>
    <timezone id="America/Bogota">哥伦比亚时间 (波哥大)</timezone>
    <timezone id="America/Caracas">委内瑞拉时间 (加拉加斯)</timezone>
    <timezone id="America/Barbados">大西洋时间 (巴巴多斯)</timezone>
    <timezone id="America/Manaus">亚马逊标准时间 (马瑙斯)</timezone>
    <timezone id="America/St_Johns">纽芬兰时间 (圣约翰)</timezone>
    <timezone id="America/Santiago">圣地亚哥</timezone>
    <timezone id="America/Argentina/Buenos_Aires">布宜诺斯艾利斯</timezone>
    <timezone id="America/Godthab">戈特霍布</timezone>
    <timezone id="America/Montevideo">乌拉圭时间 (蒙得维的亚)</timezone>
    <timezone id="America/Sao_Paulo">圣保罗</timezone>
    <timezone id="Atlantic/South_Georgia">南乔治亚</timezone>
    <timezone id="Atlantic/Azores">亚述尔群岛</timezone>
    <timezone id="Atlantic/Cape_Verde">佛得角</timezone>
    <timezone id="Africa/Casablanca">卡萨布兰卡</timezone>
    <timezone id="Europe/London">格林尼治标准时间 (伦敦)</timezone>
    <timezone id="Europe/Amsterdam">中欧标准时间 (阿姆斯特丹)</timezone>
    <timezone id="Europe/Belgrade">中欧标准时间 (贝尔格莱德)</timezone>
    <timezone id="Europe/Brussels">中欧标准时间 (布鲁塞尔)</timezone>
    <timezone id="Europe/Sarajevo">中欧标准时间 (萨拉热窝)</timezone>
    <timezone id="Africa/Brazzaville">西部非洲标准时间 (布拉扎维)</timezone>
    <timezone id="Africa/Windhoek">温得和克</timezone>
    <timezone id="Asia/Amman">东欧标准时间 (安曼)</timezone>
    <timezone id="Europe/Athens">东欧标准时间 (雅典)</timezone>
    <timezone id="Asia/Beirut">东欧标准时间 (贝鲁特)</timezone>
    <timezone id="Africa/Cairo">东欧标准时间 (开罗)</timezone>
    <timezone id="Europe/Helsinki">东欧标准时间 (赫尔辛基)</timezone>
    <timezone id="Asia/Jerusalem">以色列时间 (耶路撒冷)</timezone>
    <timezone id="Africa/Harare">中部非洲标准时间 (哈拉雷)</timezone>
    <timezone id="Europe/Minsk">明斯克</timezone>
    <timezone id="Asia/Baghdad">巴格达</timezone>
    <timezone id="Europe/Moscow">莫斯科</timezone>
    <timezone id="Asia/Kuwait">科威特</timezone>
    <timezone id="Africa/Nairobi">东部非洲标准时间 (内罗毕)</timezone>
    <timezone id="Asia/Tehran">伊朗标准时间 (德黑兰)</timezone>
    <timezone id="Asia/Baku">巴库</timezone>
    <timezone id="Asia/Tbilisi">第比利斯</timezone>
    <timezone id="Asia/Yerevan">埃里温</timezone>
    <timezone id="Asia/Dubai">迪拜</timezone>
    <timezone id="Asia/Kabul">阿富汗时间 (喀布尔)</timezone>
    <timezone id="Asia/Karachi">卡拉奇</timezone>
    <timezone id="Asia/Oral">乌拉尔</timezone>
    <timezone id="Asia/Yekaterinburg">叶卡捷林堡</timezone>
    <timezone id="Asia/Calcutta">加尔各答</timezone>
    <timezone id="Asia/Colombo">科伦坡</timezone>
    <timezone id="Asia/Katmandu">尼泊尔时间 (加德满都)</timezone>
    <timezone id="Asia/Almaty">阿拉木图</timezone>
    <timezone id="Asia/Rangoon">缅甸时间 (仰光)</timezone>
    <timezone id="Asia/Krasnoyarsk">克拉斯诺亚尔斯克</timezone>
    <timezone id="Asia/Bangkok">曼谷</timezone>
    <timezone id="Asia/Irkutsk">伊尔库茨克时间 (伊尔库茨克)</timezone>
    <timezone id="Asia/Kuala_Lumpur">吉隆坡</timezone>
    <timezone id="Australia/Perth">佩思</timezone>
    <timezone id="Asia/Yakutsk">雅库茨克时间 (雅库茨克)</timezone>
    <timezone id="Australia/Darwin">达尔文</timezone>
    <timezone id="Australia/Brisbane">布里斯班</timezone>
    <timezone id="Asia/Vladivostok">海参崴时间 (符拉迪沃斯托克)</timezone>
    <timezone id="Pacific/Guam">关岛</timezone>
    <timezone id="Australia/Adelaide">阿德莱德</timezone>
    <timezone id="Australia/Hobart">霍巴特</timezone>
    <timezone id="Australia/Sydney">悉尼</timezone>
    <timezone id="Asia/Magadan">马加丹时间 (马加丹)</timezone>
    <timezone id="Pacific/Auckland">奥克兰</timezone>
    <timezone id="Pacific/Fiji">斐济</timezone>
    <timezone id="Pacific/Tongatapu">东加塔布</timezone>
</timezones>
如果想看上面城市具体对应的时区可以调用下面的方法
     /**
      * 获取城市所在时区
      * @param targetId 目标时区id 比如:America/New_York
      * @return string 时区 比如:+08:00
      */
     public static String getTimeZone(String targetId){
    	//校验入参是否合法
        if (null == targetId || "".equals(targetId)){
            return null;
        }
    	try {
    		 TimeZone timeZone = TimeZone.getTimeZone(targetId);
        	 SimpleDateFormat outputFormat = new SimpleDateFormat("Z");
        	 outputFormat.setTimeZone(timeZone);
        	 Date date = new Date(System.currentTimeMillis());
        	 //加上冒号显示,把+0800转成+08:00
        	 StringBuffer stringBuffer = new StringBuffer(outputFormat.format(date));
        	 return stringBuffer.insert(3, ":").toString();
		} catch (Exception e) {
			e.printStackTrace();
			return null;
		}
     }
<think>我们正在讨论时区Timezone)相关的信息。根据引用内容,我们可以从Java中的TimeZone类、muduo库中的TimeZone实现,以及Flutter时区插件适配等方面来展开。 用户要求查询关于Timezone的相关信息,因此我将综合引用内容,提供关于时区的基本概念、处理方式以及在编程中的使用。 主要内容包括: 1. 时区的基本概念和重要性 2. Java中时区处理(TimeZone类,Date, Calendar, SimpleDateFormat) 3. muduo库中TimeZone的实现细节(主要关注时区转换) 4. 跨平台时区处理(如Flutter时区插件适配鸿蒙系统) 注意:引用内容中并没有提供完整的时区基础介绍,但我们可以结合已知引用和常识进行回答。 由于引用[1]和[2]主要涉及Java的TimeZone,引用[3]是muduo库中TimeZone的实现,引用[4]是关于Flutter时区适配鸿蒙,因此我们将重点放在Java和C++的时区处理上,并简要提及跨平台适配。 我们将按照以下结构回答: 一、时区的定义和作用 二、Java中的时区处理 1. TimeZone类 2. Date、Calendar和SimpleDateFormat的使用 三、C++中的时区处理(以muduo库为例) 四、跨平台时区处理(Flutter时区插件适配鸿蒙) 五、时区处理中的常见问题与注意事项 最后,生成相关问题。 注意:引用标识要自然添加在相关内容的末尾。 </think>### 时区Timezone)核心概念与实现详解 时区是协调世界时(UTC)与本地时间偏移量的规则体系,包含标准时间、夏令时切换策略及历史变更记录。以下结合引用内容解析关键技术点: --- #### 一、时区核心组成 1. **偏移量(Offset)** - GMT/UTC与本地时间的固定差值 - Java中通过 `TimeZone.getRawOffset()` 获取(单位:毫秒)[^1] - 示例: - 纽约时区:`-18000000 ms`(UTC-5) - 北京时区:`28800000 ms`(UTC+8) 2. **标识符(ID)** - 标准格式:`区域/城市`(如 `Asia/Shanghai`) - 自定义时区:通过 `TimeZone.setDefault()` 动态设置[^2] 3. **转换规则(Transition)** - 定义时区切换点(如夏令时起止)[^3]: ```c++ struct Transition { time_t gmttime; // UTC时间戳 time_t localtime; // 转换后的本地时间 int localtimeIdx; // 关联的本地时间规则索引 }; ``` --- #### 二、时区处理关键技术 ##### 1. **Java时区操作** ```java // 获取当前默认时区 TimeZone tz = TimeZone.getDefault(); // 计算北京时间与UTC的固定偏移 int offset = TimeZone.getTimeZone("Asia/Shanghai").getRawOffset(); // +28800000 ms // 动态设置自定义时区 TimeZone customTz = TimeZone.getTimeZone("GMT+3:00"); TimeZone.setDefault(customTz); ``` ##### 2. **C++时区转换(muduo实现)** - **本地时间结构**:存储偏移量与夏令时标记[^3] ```c++ struct Localtime { time_t gmtOffset; // UTC→本地时间的修正值 bool isDst; // 夏令时标志 int arrbIdx; // 时区名称索引 }; ``` - **关键算法**: - `findLocaltime()`:二分查找匹配的时区规则 - `fillHMS()`:将秒数转换为 `tm` 结构的时间表示 ##### 3. **跨平台时区适配(Flutter→鸿蒙)** - **核心挑战**:鸿蒙系统无原生时区API → 需实现桥接层 - **解决方案**[^4]: - 通过鸿蒙的 `@ohos.systemDateTime` 模块获取时区 - 封装为Dart插件 `flutter_timezone` 的统一接口 --- #### 三、时区使用典型问题 1. **偏移量计算错误** - 未区分标准时与夏令时(如 `getRawOffset()` 忽略夏令时修正) 2. **时区标识符不兼容** - Windows使用 `China Standard Time`,Linux使用 `Asia/Shanghai` 3. **跨时区序列化问题** - 时间戳存储必须附带时区ID,否则反序列化时可能偏移 --- #### 四、最佳实践建议 1. **服务端**: - 统一使用UTC时间存储与传输 - 时区信息单独存储为IANA格式(如 `Asia/Tokyo`) 2. **客户端**: - 自动获取系统时区:`TimeZone.getDefault()`(Java) / `TimeZone.system`(Dart) - 提供手动覆盖接口(如 `TimeZone.setDefault()`) 3. **全球化应用**: - 使用ICU库处理复杂时区规则(如历史变更) > **关键原则**:时间戳(timestamp)**绝对时区无关**,人类可读时间(human-readable)**必须关联时区**[^1][^3]。 ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值