【SQL】DATETIME 和 TIMESTAMP 的区别

2024-06-23 11:12

本文主要是介绍【SQL】DATETIME 和 TIMESTAMP 的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在 SQL 中,DATETIMETIMESTAMP 是用于存储日期和时间数据的两种数据类型,但它们在存储范围、时区处理和使用场景上有显著区别。以下是详细的解释:

1. DATETIME

  • 定义: DATETIME 类型用于存储日期和时间,精度为秒。
  • 格式: YYYY-MM-DD HH:MM:SS
  • 范围: 从 1000-01-01 00:00:009999-12-31 23:59:59
  • 存储: 存储的是输入的日期和时间,不受时区影响。
  • 用途: 适用于需要存储特定时间点而不考虑时区的场景,如记录事件的发生时间、日志记录等。
CREATE TABLE example_datetime (id INT AUTO_INCREMENT PRIMARY KEY,event_time DATETIME
);

2. TIMESTAMP

  • 定义: TIMESTAMP 类型用于存储日期和时间,精度为秒。它和 DATETIME 最大的区别在于它会受时区影响。
  • 格式: YYYY-MM-DD HH:MM:SS
  • 范围: 从 1970-01-01 00:00:01 UTC 到 2038-01-19 03:14:07 UTC
  • 存储: 存储的是从 1970-01-01 00:00:01 UTC 以来的秒数,会根据当前会话的时区进行转换。
  • 用途: 适用于需要存储与时区相关的时间点,如记录系统事件时间、时间戳日志等。
CREATE TABLE example_timestamp (id INT AUTO_INCREMENT PRIMARY KEY,event_time TIMESTAMP
);

特性对比

  • 时区处理:

    • DATETIME: 不处理时区,存储的是输入的时间值。
    • TIMESTAMP: 处理时区,会自动将输入的时间转换为 UTC 存储,并在查询时根据会话时区转换回本地时间。
  • 范围:

    • DATETIME: 范围更广,从 1000-01-019999-12-31
    • TIMESTAMP: 范围有限,从 1970-01-012038-01-19,受 32 位 Unix 时间戳限制。
  • 存储空间:

    • DATETIMETIMESTAMP 都占用相同的存储空间(5 字节)。

示例代码

下面是一个使用 JDBC 创建表并插入数据的示例,分别展示 DATETIMETIMESTAMP 类型的用法:

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;
import java.sql.ResultSet;
import java.sql.SQLException;public class DateTimeTimestampExample {private static final String JDBC_URL = "jdbc:mysql://localhost:3306/yourdatabase";private static final String JDBC_USER = "yourusername";private static final String JDBC_PASSWORD = "yourpassword";public static void main(String[] args) {try (Connection conn = DriverManager.getConnection(JDBC_URL, JDBC_USER, JDBC_PASSWORD);Statement stmt = conn.createStatement()) {// 创建使用 DATETIME 的表String createTableDatetimeSQL = "CREATE TABLE IF NOT EXISTS example_datetime (" +"id INT AUTO_INCREMENT PRIMARY KEY, " +"event_time DATETIME)";stmt.executeUpdate(createTableDatetimeSQL);System.out.println("Table with DATETIME created.");// 插入数据到使用 DATETIME 的表String insertDatetimeSQL = "INSERT INTO example_datetime (event_time) VALUES " +"('2024-06-17 10:00:00'), " +"('2024-06-18 12:00:00')";stmt.executeUpdate(insertDatetimeSQL);System.out.println("Data inserted into table with DATETIME.");// 查询数据ResultSet rsDatetime = stmt.executeQuery("SELECT id, event_time FROM example_datetime");System.out.println("Data from table with DATETIME:");while (rsDatetime.next()) {int id = rsDatetime.getInt("id");String eventTime = rsDatetime.getString("event_time");System.out.println("ID: " + id + ", Event Time: " + eventTime);}// 创建使用 TIMESTAMP 的表String createTableTimestampSQL = "CREATE TABLE IF NOT EXISTS example_timestamp (" +"id INT AUTO_INCREMENT PRIMARY KEY, " +"event_time TIMESTAMP)";stmt.executeUpdate(createTableTimestampSQL);System.out.println("Table with TIMESTAMP created.");// 插入数据到使用 TIMESTAMP 的表String insertTimestampSQL = "INSERT INTO example_timestamp (event_time) VALUES " +"('2024-06-17 10:00:00'), " +"('2024-06-18 12:00:00')";stmt.executeUpdate(insertTimestampSQL);System.out.println("Data inserted into table with TIMESTAMP.");// 查询数据ResultSet rsTimestamp = stmt.executeQuery("SELECT id, event_time FROM example_timestamp");System.out.println("Data from table with TIMESTAMP:");while (rsTimestamp.next()) {int id = rsTimestamp.getInt("id");String eventTime = rsTimestamp.getString("event_time");System.out.println("ID: " + id + ", Event Time: " + eventTime);}} catch (SQLException e) {e.printStackTrace();}}
}

在上述代码中,演示了如何使用 DATETIMETIMESTAMP 创建表并插入数据。请根据需要调整数据库连接字符串、用户名、密码和 SQL 语句。

总结

  • DATETIME: 不处理时区,适用于存储特定时间点而不考虑时区的场景,范围从 1000-01-019999-12-31
  • TIMESTAMP: 处理时区,适用于存储与时区相关的时间点,范围从 1970-01-012038-01-19

这篇关于【SQL】DATETIME 和 TIMESTAMP 的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1086996

相关文章

售价599元起! 华为路由器X1/Pro发布 配置与区别一览

《售价599元起!华为路由器X1/Pro发布配置与区别一览》华为路由器X1/Pro发布,有朋友留言问华为路由X1和X1Pro怎么选择,关于这个问题,本期图文将对这二款路由器做了期参数对比,大家看... 华为路由 X1 系列已经正式发布并开启预售,将在 4 月 25 日 10:08 正式开售,两款产品分别为华

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

SQL server配置管理器找不到如何打开它

《SQLserver配置管理器找不到如何打开它》最近遇到了SQLserver配置管理器打不开的问题,尝试在开始菜单栏搜SQLServerManager无果,于是将自己找到的方法总结分享给大家,对SQ... 目录方法一:桌面图标进入方法二:运行窗口进入方法三:查找文件路径方法四:检查 SQL Server 安

MySQL 中的 LIMIT 语句及基本用法

《MySQL中的LIMIT语句及基本用法》LIMIT语句用于限制查询返回的行数,常用于分页查询或取部分数据,提高查询效率,:本文主要介绍MySQL中的LIMIT语句,需要的朋友可以参考下... 目录mysql 中的 LIMIT 语句1. LIMIT 语法2. LIMIT 基本用法(1) 获取前 N 行数据(

MySQL 分区与分库分表策略应用小结

《MySQL分区与分库分表策略应用小结》在大数据量、复杂查询和高并发的应用场景下,单一数据库往往难以满足性能和扩展性的要求,本文将详细介绍这两种策略的基本概念、实现方法及优缺点,并通过实际案例展示如... 目录mysql 分区与分库分表策略1. 数据库水平拆分的背景2. MySQL 分区策略2.1 分区概念

MySQL高级查询之JOIN、子查询、窗口函数实际案例

《MySQL高级查询之JOIN、子查询、窗口函数实际案例》:本文主要介绍MySQL高级查询之JOIN、子查询、窗口函数实际案例的相关资料,JOIN用于多表关联查询,子查询用于数据筛选和过滤,窗口函... 目录前言1. JOIN(连接查询)1.1 内连接(INNER JOIN)1.2 左连接(LEFT JOI

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

MySQL中动态生成SQL语句去掉所有字段的空格的操作方法

《MySQL中动态生成SQL语句去掉所有字段的空格的操作方法》在数据库管理过程中,我们常常会遇到需要对表中字段进行清洗和整理的情况,本文将详细介绍如何在MySQL中动态生成SQL语句来去掉所有字段的空... 目录在mysql中动态生成SQL语句去掉所有字段的空格准备工作原理分析动态生成SQL语句在MySQL

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

MySQL中的交叉连接、自然连接和内连接查询详解

《MySQL中的交叉连接、自然连接和内连接查询详解》:本文主要介绍MySQL中的交叉连接、自然连接和内连接查询,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、引入二、交php叉连接(cross join)三、自然连接(naturalandroid join)四