mysql 中的datetime和timestamp的比较

本文详细比较了MySQL中TIMESTAMP与DATETIME两种日期时间类型的差异,包括存储方式、显示格式与时区处理的不同,并通过实例展示了时区变化对TIMESTAMP的影响。

 相同

  1. 显示
    TIMESTAMP列的显示格式与DATETIME列相同。换句话说,显示宽度固定在19字符,并且格式为YYYY-MM-DD HH:MM:SS。

不同

  1. 范围
         datetime 以'YYYY-MM-DD HH:MM:SS'格式检索和显示DATETIME值。支持的范围为'1000-01-01 00:00:00'到'9999-12-31 23:59:59'
         TIMESTAMP值不能早于1970或晚于2037
  2. 储存
         TIMESTAMP
    1.  
      1. 4个字节储存(Time stamp value is stored in 4 bytes)
      2. 值以UTC格式保存( it stores the number of milliseconds)
      3. 时区转化 ,存储时对当前的时区进行转换,检索时再转换回当前的时区。
         datetime
    1. 8个字节储存(8 bytes storage)
    2. 实际格式储存(Just stores what you have stored and retrieves the same thing which you have stored.)
    3. 与时区无关(It has nothing to deal with the TIMEZONE and Conversion.)



实例对比

现在我来做个时区对他们的影响。

  1. 先插入一个数据insert into `t8` values(now(), now());
  2. 改变客户端时区(东9区,日本时区)。
  3. 再次显示插入的数据,变化了,timestamp类型的数据 增加了 1个小时。



接下来 讨论一些timestamp 的其他的属性

  1. null 是否为空
    1. timestamp 默认允许为 “非空”(not null by default), 如果你在定义“ts TIMESTAMP  DEFAULT NULL” 是非法的。
    2. 可以指定为空 null ,“ts TIMESTAMP NULL"  ,这时可以在添加语句改变默认值。
      ts2 TIMESTAMP NULL DEFAULT 0,
      ts3 TIMESTAMP NULL DEFAULT CURRENT_TIMESTAMP
  2. default (一个表中只能有一个列选择下面其中一种)
    1. default CURRENT_TIMESTAMP
    2. default CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
    3. ON UPDATE CURRENT_TIMESTAMP
  3. ON UPDATE  见上2

参考文档 http://dev.mysql.com/doc/refman/5.0/en/timestamp.html

### MySQL 中 `DATETIME` `TIMESTAMP` 数据类型的区别 在 MySQL 中,`DATETIME` `TIMESTAMP` 是两种用于存储日期时间的数据类型,但它们之间存在显著的区别[^1]。以下是两者的主要差异: #### 1. 存储范围 - **`DATETIME`**:支持的日期范围是从 `'1000-01-01 00:00:00'` 到 `'9999-12-31 23:59:59'`,总共需要 8 个字节来存储每个值[^1]。 - **`TIMESTAMP`**:支持的日期范围较小,从 `'1970-01-01 00:00:01' UTC` 到 `'2038-01-19 03:14:07' UTC`,仅需 4 个字节来存储每个值[^3]。 #### 2. 存储格式 - **`DATETIME`**:MySQL 将 `DATETIME` 值以固定的格式 `'YYYY-MM-DD HH:MM:SS'` 存储显示,不依赖于时区。 - **`TIMESTAMP`**:`TIMESTAMP` 值存储为 Unix 时间戳(自 `1970-01-01 00:00:01` UTC 起的秒数),并且会根据当前时区进行转换[^3]。 #### 3. 时区支持 - **`DATETIME`**:不考虑时区信息,存储的值始终是插入时的原始值。 - **`TIMESTAMP`**:与时区密切相关。当数据插入或检索时,MySQL 会自动将 `TIMESTAMP` 值从当前时区转换为 UTC,并在检索时再转换回当前时区。 #### 4. 默认值自动更新 - **`DATETIME`**:默认情况下,`DATETIME` 不支持自动更新功能,必须显式设置其值。 - **`TIMESTAMP`**:可以定义为自动更新为当前时间戳。例如,使用 `DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP` 可以实现自动更新。 #### 5. 性能比较 尽管 `TIMESTAMP` 的存储空间更小,但在某些旧版本的数据库性能测试中,`DATETIME` 可能表现得更好[^4]。然而,现代 MySQL 版本已经优化了两者的性能差异,因此在大多数情况下,性能差异可以忽略不计。 #### 示例代码 以下是一个简单的示例,展示如何在表中使用 `DATETIME` `TIMESTAMP`: ```sql CREATE TABLE example_table ( id INT PRIMARY KEY, created_at DATETIME, updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP ); INSERT INTO example_table (id, created_at) VALUES (1, '2023-03-01 12:00:00'); ``` 在这个例子中,`created_at` 使用 `DATETIME` 类型存储固定的时间值,而 `updated_at` 使用 `TIMESTAMP` 类型并具有自动更新功能。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值