mysql 日期时间类型
datetime timestamp year date time
drop table test;
create table test (dt datetime, ts timestamp, y year, d date, t time);
insert into test values(now(),now(),now(),now(),now());
select * from test;
2018-07-14 21:55:13 , 2018-07-14 21:55:13, 2018, 2018-07-14, 21:55:13
timestamp
1、timestamp 值返回后显示为“YYYY-MM-DD HH:MM:SS”格式的字符串,显示宽度固定为 19 个字符。如果想要获得数字值,应在 timestamp 列添加+0。
select ts+0 from test; // 20180714215513
2、系统给 timestamp 自动创建默认值 current_timestamp
drop table test;
create table test(id timestamp);
insert into test values(null);
select * from test; // 2007-07-04 16:37:24
注意,MySQL只给表中的第一个timestamp字段设置默认值为系统日期,如果有第二个timestamp类型,则默认值设置为0值。
alter table test add id2 timestamp;
insert into test values(null, null);
select * from test; // 2018-07-14 21:04:15 0000-00-00 00:00:00
可以修改id2的默认值为其他常量日期,但是不能再修改为current_timestmap,因为MySQL规定timestamp类型字段只能有一列的默认值为current_timestmap,如果强制修改,系统会报错。
drop table test;
create table test(id timestamp, id2 timestamp);
alter table test alter column id2 set default current_timestamp; // 报错
alter table test alter column id2 set default 20180714215513;
3、timestamp还有一个重要特点,就是和时区相关。当插入日期时,会先转换为本地时区后存放;而从数据库里面取出时,也同样需要将日期转换为本地时区后显示。这样,两个不同时区的用户看到的同一个日期可能是不一样的。
drop table test;
create table test (
`id1` timestamp not null default current_timestamp,
`id2` datetime default null
)
show variables like 'time_zone'; // SYSTEM 查看当前时区,我们在中国,这里的“SYSTEM”实际是东八区(+8:00)
insert into t8 values(now(), now());
select * from t8;
| 2007-09-25 17:26:50 | 2007-09-25 17:26:50 |
修改时区为东九区: set time_zone='+9:00';
select * from t8;
| 2007-09-25 18:26:50 | 2007-09-25 17:26:50 |
timestamp和datetime的表示方法非常类似,区别主要有以下几点。
1、timestamp支持的时间范围较小,其取值范围从19700101080001到2038年的某个时间,而datetime是从1000-01-01 00:00:00到9999-12-31 23:59:59,范围更大。
2、表中的第一个timestamp列自动设置为系统时间。如果在一个timestamp列中插入null,则该列值将自动设置为当前的日期和时间。在插入或更新一行但不明确给timestamp列赋值时也会自动设置该列的值为当前的日期和时间,当插入的值超出取值范围时,mysql认为该值溢出,使用“0000-00-00 00:00:00”进行填补。
3、timestamp的插入和查询都受当地时区的影响,更能反应出实际的日期。而datetime则只能反应出插入时当地的时区,其他时区的人查看数据必然会有误差的。
mysql 日期时间类型的更多相关文章
- mysql日期时间类型总结
MySQL 日期类型:日期格式.所占存储空间.日期范围 比较. 日期类型 存储空间 日期格式 日期范围 ------------ ---- ...
- Mysql 日期时间类型详解
MySQL 中有多种数据类型可以用于日期和时间的表示,不同的版本可能有所差异,表3-2 中列出了MySQL 5.0 中所支持的日期和时间类型. 这些数据类型的主要区别如下: * 如果要用来表示年月日 ...
- mysql 日期时间类型 自动转型 及 运算
日期时间类型自动转型 -- now().字符串.数字转datetime类型 create table t(dt datetime);insert into t values(now());insert ...
- MySQL 日期时间类型怎么选?千万不要乱用!
构建数据库写程序避免不了使用日期和时间,对于数据库来说,有多种日期时间字段可供选择,如 timestamp 和 datetime 以及使用 int 来存储 unix timestamp. 不仅新手,包 ...
- Mysql 建表时,日期时间类型选择
mysql(5.5)所支持的日期时间类型有:DATETIME. TIMESTAMP.DATE.TIME.YEAR. 几种类型比较如下: 日期时间类型 占用空间 日期格式 最小值 最大值 零值表示 D ...
- MySQL学习分享-->日期时间类型
日期时间类型 ①如果要用来表示年月日时分秒,一般使用datetime类型: ②如果要用来表示年月日,一般使用date类型: ③如果要表示时分秒,一般使用time类型: ④如果只是表示年份,一般使用ye ...
- MySQL之日期时间类型
mysql(5.5)所支持的日期时间类型有:DATETIME. TIMESTAMP.DATE.TIME.YEAR. 几种类型比较如下: 日期时间类型 占用空间 日期格式 最小值 最大值 零值表示 D ...
- MySQL 中的日期时间类型
日期时间类型中包含以下几种数据类型: DATE TIME DATETIME TIMESTAMP YEAR 各类型都有具体的取值范围,超出或非法的其他值时,MySQL 会回退到 0.TIMESTAMP ...
- MySQL建表时,日期时间类型选择
MySQL(5.5)所支持的日期时间类型有:DATETIME. TIMESTAMP.DATE.TIME.YEAR. 几种类型比较如下: 日期时间类型 占用空间 日期格式 最小值 最大值 零值表示 D ...
随机推荐
- python中的sort方法使用详解
Python中的sort()方法用于数组排序,本文以实例形式对此加以详细说明: 一.基本形式 列表有自己的sort方法,其对列表进行原址排序,既然是原址排序,那显然元组不可能拥有这种方法,因为元组是不 ...
- python字符串中包含Unicode插入数据库乱码问题 分类: Python 2015-04-28 18:19 342人阅读 评论(0) 收藏
之前在编码的时候遇到一个奇葩的问题,无论如何操作,写入数据库的字符都是乱码,之后是这样解决的,意思就是先解码,然后再插入数据库 cost_str = json.dumps(cost_info) cos ...
- JavaScript -- 猜数、遍历
----- 004-猜数.html ----- <!DOCTYPE html> <html> <head> <meta http-equiv="Co ...
- android学习-IPC机制之ACtivity绑定Service通信
bindService获得Service的binder对象对服务进行操作 Binder通信过程类似于TCP/IP服务连接过程binder四大架构Server(服务器),Client(客户端),Serv ...
- springboot-26-springboot 集成rabbitmq
rabbitmq是基于AMQP规范的一个消息代理, 它可以兼容jms, 支持其他语言, 并且可以跨平台 1, 安装 1) 普通安装 度娘: 2) docker 安装 sudo docker run - ...
- 解决php中文乱码
在文件的第一行,加入下面这一句: header("Content-Type: text/html; charset=utf8"); 然后在把文件以utf-8的格式保存起来就行了
- elasticsearch分析系列
http://www.opscoder.info/category/ElasticSearch/?page=2 https://www.jianshu.com/p/0908b9ee65fc https ...
- ruby 数据sql操作
ActiveRecord ActiveRecord 是 Rails 的 ORM 元件,負責與資料庫溝通,讓我們可以用物件導向的語法操作資料庫.在”打造 CRUD 應用程式”一章中提到的對應概念如下: ...
- [转]C#进阶系列——WebApi 接口参数不再困惑:传参详解
本文转自:http://www.cnblogs.com/landeanfen/p/5337072.html#_label1_2 阅读目录 一.get请求 1.基础类型参数 2.实体作为参数 3.数组作 ...
- Start transaction not working with Revit 2014
You're right, it's not being used correctly. The Transaction needs to take place inside the Idling e ...