mysql时间戳和datetime对比(mysql中 datatime与timestamp的区别说明)
mysql时间戳和datetime对比
mysql中 datatime与timestamp的区别说明mysql中有三种日期类型:
date(年-月-日)
create table test(hiredate date);
datetime(日期时间类型)
create table test(hiredate datetime)
timestamp(邮戳类型,保存年-月-日 时-分-秒)
create table test(hiredate timestamp)
datetime 和timestamp的不同点
1、两者的存储方式不一样
对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。而对于DATETIME,不做任何改变,基本上是原样输入和输出。
2、两者所能存储的时间范围不一样
timestamp所能存储的时间范围为:'1970-01-01 00:00:01.000000' 到 ‘2038-01-19 03:14:07.999999'。
datetime所能存储的时间范围为:'1000-01-01 00:00:00.000000' 到 ‘9999-12-31 23:59:59.999999'。
总结:TIMESTAMP和DATETIME除了存储范围和存储方式不一样,没有太大区别。当然,对于跨时区的业务,TIMESTAMP更为合适。
3、自动初始化和更新
自动初始化指的是如果对该字段(譬如上例中的hiredate字段)没有显性赋值,则自动设置为当前系统时间。
自动更新指的是如果修改了其它字段,则该字段的值将自动更新为当前系统时间。
它与“explicit_defaults_for_timestamp”参数有关。
默认情况下,该参数的值为OFF
|
mysql> show variables like '%explicit_defaults_for_timestamp%' ; + ---------------------------------+-------+ | Variable_name | Value | + ---------------------------------+-------+ | explicit_defaults_for_timestamp | OFF | + ---------------------------------+-------+ row in set (0.00 sec) |
总结:timestamp有自动初始化和更新,当你update某条记录的时候,该列值会自动更新,这是和datatime最大的区别。
补充:DATETIME与TIMESTAMP的一些区别与问题
今天遇到一个问题,明明数据有更新,update_time字段却还停留在创建数据的时候。
按常理来说这个字段应该是自动更新的才对。
查了一下表结构,
|
`update_time` datetime NOT NULL DEFAULT CURRENT_TIMESTAMP |
发现update_time字段的类型是datetime
由此牵扯出两个问题,(1)timestamp与datetime的区别;(2)CURRENT_TIMESTAMP为什么能用于datetime类型
timestamp与datetime的区别
a)DATETIME的默认值为null;TIMESTAMP的字段默认不为空(not null),默认值为当前时间(CURRENT_TIMESTAMP),如果不做特殊处理,并且update语句中没有指定该列的更新值,则默认更新为当前时间。
这个区别就解释了为什么平时我们都不用可以管这个字段就能自动更新了,因为多数时候用的是timestamp;而此处用的是datetime,不会有自动更新当前时间的机制,所以需要在上层手动更新该字段
b)DATETIME使用8字节的存储空间,TIMESTAMP的存储空间为4字节。因此,TIMESTAMP比DATETIME的空间利用率更高。
这个区别解释了为啥timestamp类型用的多
c)两者的存储方式不一样 ,对于TIMESTAMP,它把客户端插入的时间从当前时区转化为UTC(世界标准时间)进行存储。查询时,将其又转化为客户端当前时区进行返回。而对于DATETIME,不做任何改变,基本上是原样输入和输出。
d)两者所能存储的时间范围不一样
timestamp所能存储的时间范围为:'1970-01-01 00:00:01.000000' 到 ‘2038-01-19 03:14:07.999999';
datetime所能存储的时间范围为:'1000-01-01 00:00:00.000000' 到 ‘9999-12-31 23:59:59.999999'。
CURRENT_TIMESTAMP为什么能用于datetime类型
在mysql 5.6之前的版本,CURRENT_TIMESTAMP只能用于timestamp类型,
5.6版本之后,CURRENT_TIMESTAMP也能用于datetime类型了
select version()查了一下数据库发现确实版本是5.6.29
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/u014696474/article/details/70568733
- mysql日志功能介绍(mysql日志系统的简单使用教程)
- mysqlset用法(mysql descDESCRIBE命令实例讲解)
- mysql突然报错206无法连接(详解MySQL连接挂死的原因)
- mysql数据库死锁原理(MySQL数据库锁机制原理解析)
- 将mysql中的表导出来(MySQL之导出整个及单个表数据的操作)
- mysql剩余表空间大小(MySQL 表空间碎片的概念及相关问题解决)
- mysql8.0安装教程win10(Windows10下mysql 8.0.22 安装配置方法图文教程)
- mysql事务特性和隔离级别(Mysql事务特性和级别原理解析)
- mysql怎么设置存储记录(MySQL 的一行记录是怎么存储的?)
- mysql使用步骤(聊一聊MySQL角色Role功能)
- 在php中与数据库连接的技术(PHP7.0连接DB操作实例分析基于mysqli)
- MySQL中NULL和空值的区别
- myeclipse连接mysql数据库的方法(教你用eclipse连接mysql数据库)
- 查看mysql所有权限(MySQL 权限控制细节分析)
- mysql 安装阿里云(详解如何在阿里云服务器安装Mysql数据库)
- mysqlreplace用法(细说mysql replace into用法)
- 医事文化谈屑 | 古人的名 字 号(医事文化谈屑古人的名)
- ()
- 网友很惭愧,自己写了很多年的字,到头来还不如一名小学生写的好(自己写了很多年的字)
- 中华第一楷 张瑞龄 86岁高龄,苦练楷书71年,一幅字卖593万(中华第一楷张瑞龄)
- 冯骥才 年意(冯骥才年意)
- ()
热门推荐
- SQL join中on与where区别
- python爬取在线评论(Python爬虫实现爬取百度百科词条功能实例)
- 小鸟云服务器怎么买(小鸟云服务器忘记密码怎么办?小鸟云密码找回图文教程)
- python3.7不兼容pywinauto(浅谈python编译pyc工程--导包问题解决)
- python类继承和封装(Python面向对象程序设计类的封装与继承用法示例)
- python3 for循环怎么用(Python3.5基础之变量、数据结构、条件和循环语句、break与continue语句实例详解)
- python获取游戏画面信息(python游戏开发之视频转彩色字符动画)
- python获取股票每天k线(使用PyQtGraph绘制精美的股票行情K线图的示例代码)
- dede后台建栏目(DedeEIMS后台栏目模板含单独页模板修改方法)
- pythonturtle库画图代码(用Python中的turtle模块画图两只小羊方法)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9