mysql的timestamp字段和serverTimezone的关系

1. mysql中timestamp字段类型的定义:表示从1970年1月1日0点0分1秒开始到存储时间之间的秒数,最高到2038年1月19号3点14分07秒

这个怎么理解呢?就是不管你当前的时区是什么,当你存入一个时间类型的数据的时候,mysql都会将该时间转化成utc时间1970-01-01 00:00:00 开始到现在的秒数。
<1>如果mysql服务器设置的时区,也就是time_zone是'+00:00'时
当我们以字符串的形式存入数据的时候,最小只能存入'1970-01-01 00:00:01',如果存'1970-01-01 00:00:00'就会报错(sql_mode为严格)

com.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Incorrect datetime value: '1970-01-01 00:00:00' for column 'update_time' at row 1

大于等于'2038-01-19 03:14:08'的时候报同样的错误,其实就是超出范围了。所以使用这个字段类型需要注意,只能到2038年,否则就会出现溢出的问题

<2>如果mysql服务器设置的时区,也就是time_zone是'+08:00'时
当我们以字符串的形式存入数据的时候,最小只能存入'1970-01-01 08:00:01',如果存'1970-01-01 08:00:00'就会报错(sql_mode为严格)
com.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Incorrect datetime value: '1970-01-01 00:00:00' for column 'update_time' at row 1
为什么明明要存入的是'1970-01-01 08:00:00',却报错'1970-01-01 00:00:00'呢?
原因就在于time_zone是'+08:00'时,mysql在存储timstamp的时候,会将时间转换为UTC时间。
因为服务器设置的是东八区,所以进行转换的时候会将时间提前8小时,这个就是跟报了sql语句不一样的时间错误,究其原因就是存储时候转换导致的

2. 我们平时在使用jdbc连接mysql的时候,常常会在url中设置一个时区参数,例如:jdbc:mysql://${ip}:3306/test?serverTimezone=Asia/Shanghai&characterEncoding=UTF-8
这个参数到底是干什么用的呢,有什么影响呢?(下载的内容是我根据推测和实验得出的结论,可能不全对,如果哪位兄台发现错误请不吝赐教)
<1> 这个参数只对日期类型的数据起作用,对字符串类型的数据是没有作用。

final Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test?serverTimezone=Asia/Shanghai&characterEncoding=UTF-8","utest", "upd@231224aaa");final Statement statement = conn.createStatement();statement.execute("insert into t_test values(1, '2038-01-19 03:14:08')");

例如:当我们执行insert into t_test values(1, '1970-01-01 08:00:01')的时候,无论jdbcurl中的serverTimezone指定的时区是东八区,还是utc,没有任何区别
那它的作用是什么?经过测试,当我们使用java代码中的Date类型存储数据的时候,这个参数就会起作用,它起的作用是:在进入mysql之前,将jvm中Date的时区根据这个参数先进行一次转化,例如:

@Testpublic void testTimeZone() throws SQLException {final Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/test?serverTimezone=UTC&characterEncoding=UTF-8","utest", "upd@231224aaa");final PreparedStatement preparedStatement = conn.prepareStatement("insert into t_test(update_time) values(?)");final DateTime dateTime = DateUtil.parseDateTime("1970-01-01 08:00:01");preparedStatement.setObject(1, dateTime);preparedStatement.execute();}

我代码里使用了hutool的工具,DateTime只是将对Date一个简单封装,可以当成util.Date看待
因为我的本地jvm的时区是东八区,而url中设置的UTC,所以,在存入mysql的时候,会先将DateTime减去8小时,而如果你的mysql的time_zone为东八区的时候,就会报上面同样的错误.
com.mysql.cj.jdbc.exceptions.MysqlDataTruncation: Data truncation: Incorrect datetime value: '1970-01-01 00:00:01.0' for column 'update_time' at row 1
这个是因为:在存储的时候,会再一次进行转换,mysql会将已经减了8小时的时间转成utc偏移的秒数,会再减去8小时,此时就会报错

综合上面两点,我们可以看出来,在使用时间字符串存储mysql的timestamp字段的时候,跟url里的serverTimezone无关,而使用Date存储的时候,会根据这个进行时区转换,然后物理存储的时候再转成UTC偏离的秒数.
Date对象进行存储Date时区 -> (如果)serverTimezone不指定,则不会进行这步的转换)serverTimezone的时区 -> 转成UTC秒存储
String语句进行存储 -> 转成UTC秒存储

理解了转换的过程,我们来测试一个现实中的问题,服务器时区设置为time_zone='+8:00'的时候,jvm时区是+8:00,在url不设置时区,存储一个2023-12-25 08:00:00
所看到的时间是2023-12-25 08:00:00
当我们将url中的serverTimezone设置为UTC的时候(注意我的JVM时区仍然是东八区)会是什么结果呢?
1. 从mysql中读取出来的时候仍然是2023-12-25 08:00:00,由于serverTimezone,JVM时区是东八区,会导致进入jvm的时候再转一次,次数该时间变为'2023-12-25 16:00:00'
我最开始测试的时候忽略了JVM时区的转换,一直无法解释测试结果和理论结果对不上的问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/577653.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

算法问题:最优二叉搜索树

给定一个序列 有n个有序且各不相同的键&#xff0c; 集合表示在K中成功的搜索的概率; 为n1 个不同的哑键&#xff0c;表示所有在和之间的值&#xff0c; 表示不成功的搜索的概率. 创建二叉搜索树&#xff0c; 使得其期望搜索花费最小。 一个例子 最优子结构 如果一棵最优二叉搜…

udp多播/组播那些事

多播与组播 多播&#xff08;multicast&#xff09;和组播&#xff08;groupcast&#xff09;是相同的概念&#xff0c;用于描述在网络中一对多的通信方式。在网络通信中&#xff0c;单播&#xff08;unicast&#xff09;是一对一的通信方式&#xff0c;广播&#xff08;broad…

某日某条完整逆向分析和数据抓取(最详细逆向实战教程,小白也能看懂)

大家好!我是爱摸鱼的小鸿,关注我,收看每期的编程干货。 本期文章将带你详细的逆向分析某日某条的URL加密参数,包括如何逆向分析、如何准确的找到加密入口、如何补JS环境、如何模拟执行JS,以及如何用网络劫持简单便捷的获取URL加密参数、接口监听的方式直接获取接口响应数据…

Mybatis如何兼容各类日志?

文章目录 适配器模式日志模块代理模式1、静态代理模式2、JDK动态代理 JDBC Logger总结 Apache Commons Logging、Log4j、Log4j2、java.util.logging 等是 Java 开发中常用的几款日志框架&#xff0c;这些日志框架来源于不同的开源组织&#xff0c;给用户暴露的接口也有很多不同…

边缘计算AI智能盒子的视频源必须是固定点监控摄像头吗?

边缘计算AI盒子的视频输入源&#xff0c;要求是RTSP或者GB28181&#xff0c;可以是固定点监控摄像头&#xff08;枪机、球机等&#xff09;&#xff0c;也可以是移动摄像头&#xff0c;例如执法记录仪、智能安全帽、布控球等&#xff0c;但由于RTSP输入要求摄像头有固定IP&…

使用 Postman 进行并发请求:实用教程与最佳实践

背景介绍 最近&#xff0c;我们发起了一个在线图书管理系统的项目。我负责的一个关键模块包括三个主要后台接口&#xff1a; 实现对books数据的检索。实施对likes数据的获取。通过collections端点访问数据。 应对高流量的挑战 在设计并部署接口时&#xff0c;我们不可避免地…

C语言初学8:函数和作用域

一、函数 函数声明告诉编译器函数的名称、返回值类型和参数。在一个源文件中定义函数且在另一个文件中调用函数时&#xff0c;函数声明是必需的。函数定义提供了函数的实际主体。

JavaScript力扣88题

splice方法&#xff1a;nums.splice(start,deletenum,newitem1,newitem2,new...); splice(铰接&#xff0c;捻接)&#xff1b;start&#xff1a;开始的位置&#xff0c;从1开始&#xff1b;deletenum,删除的数量&#xff1b;nuwitem1,...新添加的元素 代码示例&#xff1a; l…

西南科技大学计算机网络实验二 (IP协议分析与以太网协议分析)

一、实验目的 通过分析由跟踪执行traceroute程序发送和接收捕获得到的IP 数据报,深入研究在IP 数据报中的各种字段,理解IP协议。基于ARP命令和Ethereal进行以太网帧捕获与分析,理解和熟悉ARP协议原理以及以太网帧格式。 二、实验环境 与因特网连接的计算机网络系统;主机操…

编写第一个APP自动化脚本 appium_helloworld ,将脚本跑起来

一、前置说明 我们把学习 Appium 的第一个脚本称为 appium_helloworld&#xff0c;它用于展示 Appium 的基本用法&#xff0c;验证配置和环境是否正确。 Appium 自动化操作 APP 的基本流程&#xff08;Android平台&#xff09;&#xff1a; 启动 Appium Serveradb 连接设备&…

【ctf】whireshark流量分析之tcp_杂篇

目录 简介 常考 图片类 提取png.pcap&#xff08;常规&#xff09; 异常的流量分析&#xff08;*&#xff0c;特殊&#xff09; john-in-the-middle&#xff08;特殊&#xff09; ​编辑 zip类 1.pcap&#xff08;常规&#xff09; 方法1&#xff08;常规提取压缩包&…

[足式机器人]Part4 南科大高等机器人控制课 CH10 Bascis of Stability Analysis

本文仅供学习使用 本文参考&#xff1a; B站&#xff1a;CLEAR_LAB 笔者带更新-运动学 课程主讲教师&#xff1a; Prof. Wei Zhang 南科大高等机器人控制课 Ch10 Bascis of Stability Analysis 1. Background1.1 What is Stability Analysis1.2 General ODE Models for Dynamic…

Web前端VScode/Vue3/git/nvm/node开发环境安装

目录 1 基本配置 2 安装vscode 3 安装vue 4 配置bash 5 安装nvm 6 安装node 7 安装yarn 8 新建项目 9 运行helloworld 1 基本配置 本篇是为了做前端开发的环境而写。使用的操作系统是windows 10 64位 2 安装vscode 现在做vue和node基本就是vscode和webstorm&#x…

Cesium.js三维地图的实现(依托天地图CDN文件)

零、技术选型&#xff1a; Vue2、VueCli5、天地图、Cesium.js 一、通过天地图官网案例实现 需要引入天地图官方提供的CDN链接访问Cesium.js相关文件 相关文件&#xff1a; https://api.tianditu.gov.cn/cdn/demo/sanwei/static/cesium/Cesium.js https://api.tianditu.gov.cn/…

【WPF.NET开发】数据绑定应用场景

目录 1、实现属性更改通知 示例 2、双向绑定​​​更新源 示例 3、对分层数据使用主-从模式 示例 4、对分层 XML 数据使用主-从模式 示例 5、绑定两个控件的属性 示例 6、创建和绑定到 ObservableCollection 示例 7、使用 XMLDataProvider 和 XPath 查询绑定到 XML…

喜报!酷克数据携手中移在线入选2023大数据“星河”数据库优秀案例

12月20日-21日&#xff0c;由中国信通院、中国通信标准化协会主办&#xff0c;中国通信标准化协会大数据技术标准推进委员会承办的“2023数据资产管理大会”在京召开。 在会上&#xff0c;第七届大数据“星河&#xff08;Galaxy&#xff09;”案例评选结果正式公布。中移在线服…

华纳云:组策略与注册表之间的区别和联系

组策略和注册表是在 Windows 操作系统中用于配置和管理系统行为的两种不同的管理机制。它们之间有着紧密的联系&#xff0c;但也有一些重要的区别。 区别&#xff1a; 定义和作用&#xff1a; 组策略&#xff1a; 组策略是一种集中管理和配置 Windows 系统设置的机制。通过组策…

如何在Laravel中屏蔽错误提示(两种方法)

前言 Laravel是一个非常流行的PHP框架&#xff0c;其提供的错误提示机制使得在开发过程中出现问题时可以迅速定位原因&#xff0c;从而提高了开发效率。然而&#xff0c;有时候我们在正式上线的时候&#xff0c;不希望用户看到任何错误提示&#xff0c;这时候我们可以通过屏蔽…

Java 中 Stream 流的使用方法

目录 一、Stream 的概念 二、Stream 的特点 三、Stream 的使用步骤 1、Stream 的创建 1.1、通过Collection对象的stream()或parallelStream()方法 1.1.1、stream() 和 parallelStream() 两个方法的区别 1.2、通过 Arrays 工具类的 stream() 方法 1.3、通过Stream接口的of()…

Local Binary Convolutional Neural Networks (LBCNN)

论文&#xff1a;https://arxiv.org/abs/1608.06049 代码&#xff1a;GitHub - juefeix/lbcnn.torch: Torch implementation of CVPR17 - Local Binary Convolutional Neural Networks http://xujuefei.com/lbcnn.html 摘要&#xff1a; 我们提出了局部二值卷积(LBC)&#x…