标签(空格分隔): MYSQL


基本说明

YEAR类型

YEAR类型是一个单字节类型用于表示年。
MySQL以YYYY格式检索和显示YEAR值。范围是1901到2155。

给YEAR类型赋值方法:

1 直接插入4位字符串

范围为’1901’到’2155’

2 直接插入4位数字

范围为1901到2155

3 插入2位字符串

如果插入‘00’~‘69’,则相当于插入2000~2069;
如果插入‘70’~‘99’,则相当于插入1970~1999。

‘0’ 和 ‘00’效果相同,都是表示2000年。

4 插入2位数字

范围为1到99
如果插入1~69,则相当于插入2001~2069;
如果插入70~99,则相当于插入1970~1999。

请注意两位整数范围与两位字符串范围稍有不同,因为你不能直接将零指定为数字并将它解释为2000。你必须将它指定为一个字符串’0’或’00’,插入数字0将被解释为0000。

5 函数返回的结果,其值适合YEAR上下文,例如NOW()

TIME类型

TIME类型表示为“时:分:秒”,尽管小时范围一般是0~23,但是为了表示某些特殊时间间隔,MySQL将TIME的小时范围扩发了,而且支持负值。
对TIME类型赋值,标准格式是‘HH:MM:SS’,但不一定非要是这种格式。
如果插入的是‘D HH:MM:SS’格式,则类似插入了‘(D*24+HH):MM:SS’。比如插入‘2 23:50:50’,相当于插入了‘71:50:50’。
如果插入的是‘HH:MM’或‘SS’格式,则效果是其他未被表示位的值赋为零值。比如插入‘30’,相当于插入了‘00:00:30’;如果插入‘11:25’,相当于插入了‘11:25:00’。
另外也可以插入‘D HH’和‘D HH:MM’,效果按上面的例子可以推理出来了吧。
在MySQl中,对于’HHMMSS’格式,系统能够自动转化为标准格式。
如果我们想插入当前系统的时间,则可以插入CURRENT_TIME或者NOW()。TIME类型只占3个字节,如果只是存储时间数据,它最合适了

DATETIME类型

标准格式为“YYYY-MM-DD HH:MM:SS”,具体赋值方法与上面各种类型的方法相似。

TIMESTAMP类型

插入数据方法
1. 使用CURRENT_TIMESTAMP
2. 输入NULL
3. 无任何输入

取值范围

类型

字节

范围

格式

用途

YEAR

1

[1901,2155]

YYYY

年份值

DATE

4

[1000-01-01,9999-12-31]

YYYY-MM-DD

日期值

TIME

3

[-838:59:59,838:59:59]

HH:MM:SS

时间值或持续时间

DATETIME

8

[1000-01-01 00:00:00 , 9999-12-31 23:59:59]

YYYY-MM-DD HH:MM:SS

混合日期和时间值

TIMESTAMP

4

[19700101080001,20380119111407]

YYYYMMDD HHMMSS

混合日期和时间值,时间戳