mysql中Timestamp,Time,Datetime 区别
一、TIMESTAMP[(M)]
时间戳。范围是’1970-01-01 00:00:00’到2037年。
TIMESTAMP列用于INSERT或UPDATE操作时记录日期和时间。
如果你不分配一个值,表中的第一个TIMESTAMP列自动设置为最近操作的日期和时间。
也可以通过分配一个NULL值,将TIMESTAMP列设置为当前的日期和时间。
TIMESTAMP值返回后显示为’YYYY-MM-DD HH:MM:SS’格式的字符串,
显示宽度固定为19个字符。如果想要获得数字值,应在TIMESTAMP 列添加+0。
create table demo(
addtime timestamp
);
insert into demo values(null);
即可插入当前时间。
二、TIME
时间。范围是’-838:59:59’到’838:59:59’。
MySQL以’HH:MM:SS’格式显示TIME值,但允许使用字符串或数字为TIME列分配值。
使用now()显示’HH:MM:SS’
使用UNIX_TIMESTAMP()显示’-838:59:59’到’838:59:59’。
mysql> insert into pluralpoem(title, create_time) values("chunxiao", UNIX_TIMESTAMP());
Query OK, 1 row affected, 1 warning (0.01 sec)
mysql> insert into pluralpoem(title, create_time) values("hua",now());
Query OK, 1 row affected (0.00 sec)
mysql> select * from pluralpoem;
+----+------------+-------------+
| id | title | create_time |
+----+------------+-------------+
| 1 | denggaowan | NULL |
| 2 | chunxiao | 838:59:59 |
| 3 | hua | 22:45:33 |
+----+------------+-------------+
3 rows in set (0.00 sec)
三、DATETIME
日期和时间的组合。
支持的范围是’1000-01-01 00:00:00’到’9999-12-31 23:59:59’。
MySQL以’YYYY-MM-DD HH:MM:SS’格式显示DATETIME值,但允许使用字符串或数字为DATETIME列分配值。
四、对于now().,curdate(),curtime(), UNIX_TIMESTAMP()
NOW()函数以`'YYYY-MM-DD HH:MM:SS'返回当前的日期时间,可以直接存到DATETIME字段中。
CURDATE()以’YYYY-MM-DD’的格式返回今天的日期,可以直接存到DATE字段中。
CURTIME()以’HH:MM:SS’的格式返回当前的时间,可以直接存到TIME字段中。
UNIX_TIMESTAMP() 得到当前时间戳