Mysql中的日期和时间

MySQL 使用下列数据类型在数据库中存储日期或日期/时间值:
• DATE - 格式 YYYY-MM-DD
• DATETIME - 格式: YYYY-MM-DD HH:MM:SS
• TIMESTAMP - 格式: YYYY-MM-DD HH:MM:SS
• YEAR - 格式 YYYY 或 YY

date用curdate()获取当前时间
而datetime 和 timestamp都用 now()来获取当前时间
date () 函数返回日期或日期/时间表达式的 日期部分

其他函数 在 下面的链接里可以查到
http://www.w3school.com.cn/sql/sql_dates.asp

为什么不用
首先 DATETIM和TIMESTAMP类型所占的存储空间不同,前者8个字节,后者4个字节,这样造成的后果是两者能表示的时间范围不同。前者范围为1000-01-01 00:00:00 ~ 9999-12-31 23:59:59,后者范围为1970-01-01 08:00:01到2038-01-19 11:14:07。所以可以看到TIMESTAMP支持的范围比DATATIME要小,容易出现超出的情况.
其次,TIMESTAMP类型在默认情况下,insert、update 数据时,TIMESTAMP列会自动以当前时间(CURRENT_TIMESTAMP)填充/更新。
第三,TIMESTAMP比较受时区timezone的影响以及MYSQL版本和服务器的SQL MODE的影响

猜你喜欢

转载自blog.csdn.net/qq_19934363/article/details/88367597