mysql中Timestamp,time,datetime 區(qū)別
????一、TIMESTAMP[(M)]
???? 時(shí)間戳。范圍是’1970-01-01 00:00:00’到2037年。
TIMESTAMP列用于INSERT或UPDATE操作時(shí)記錄日期和時(shí)間。
如果你不分配一個(gè)值,表中的第一個(gè)TIMESTAMP列自動(dòng)設(shè)置為最近操作的日期和時(shí)間。
也可以通過(guò)分配一個(gè)NULL值,將TIMESTAMP列設(shè)置為當(dāng)前的日期和時(shí)間。
TIMESTAMP值返回后顯示為’YYYY-MM-DD HH:MM:SS’格式的字符串,
顯示寬度固定為19個(gè)字符。如果想要獲得數(shù)字值,應(yīng)在TIMESTAMP 列添加+0。
create table demo(
addtime timestamp
);
insert into demo values(null);
即可插入當(dāng)前時(shí)間。
二、TIME
時(shí)間。范圍是’-838:59:59’到’838:59:59’。
MySQL以’HH:MM:SS’格式顯示TIME值,但允許使用字符串或數(shù)字為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
日期和時(shí)間的組合。
支持的范圍是’1000-01-01 00:00:00’到’9999-12-31 23:59:59’。
MySQL以’YYYY-MM-DD HH:MM:SS’格式顯示DATETIME值,但允許使用字符串或數(shù)字為DATETIME列分配值。
????四、對(duì)于now().,curdate(),curtime(),?UNIX_TIMESTAMP()
???? NOW()函數(shù)以`'YYYY-MM-DD HH:MM:SS'返回當(dāng)前的日期時(shí)間,可以直接存到DATETIME字段中。
CURDATE()以’YYYY-MM-DD’的格式返回今天的日期,可以直接存到DATE字段中。
CURTIME()以’HH:MM:SS’的格式返回當(dāng)前的時(shí)間,可以直接存到TIME字段中。
???? UNIX_TIMESTAMP()
????
????
????
????