MySQL 5第四次学科练习

2013-05-15_155548

这是第四次ㄚ琪自我练习的结果,测试50题,答对41题得82分,错9题扣9分,总计得分73分,跟第二次一样,且这三次的分数都差不多,看来要80分以上是一个很大的瓶颈。就让我们继续努力练习吧。

2013-05-15_155837

这是MySQL 5实力养成暨评量里的4-34.‘在MySQL中,时间日期资料型态支援“非严格型”语法,任何标点符号均可作为日期或时间的间隔符号,所以以下哪些是合法的日期输入?’

答案:(A) 06-10-31 (B) 06@10@31 (C) 06.10.31 (D) 06@10.31

[adsense][/adsense]

这一题会错误的原因,在于ㄚ琪觉得@不是标点符号,所以我们来检查一下手册的说明吧。

MySQL 5.7 Reference Manual :: 9 Language Structure :: 9.1 Literal Values :: 9.1.3 Date and Time Literals

MySQL 5.1参考手册 :: 11. 列类型::11.3. 日期和时间类型::11.3.1. DATETIME、DATE和TIMESTAMP类型

转译繁体如下:

DATETIME、DATE和TIMESTAMP类型是相关的。该节描述了它们的特征,它们的相似点和不同点。

当您需要同时包含日期和时间讯息的值时则使用DATETIME类型。MySQL以’YYYY-MM-DD HH:MM:SS’格式检索和显示DATETIME值。支援的范围为’1000-01-01 00:00:00’到’9999-12-31 23:59:59′。(“支援”资料表示尽管先前的值可能工作,但没有保证)。

当您只需要日期值而不需要时间部分时应使用DATE类型。MySQL用’YYYY-MM-DD’格式检索和显示DATE值。支援的范围是’1000-01-01’到’9999-12-31′

TIMESTAMP列类型的属性不固定,取决于MySQL版本和伺服器运行的SQL模式。这些属性将在本节后面描述。

可以使用任何常见格式指定DATETIME、DATE和TIMESTAMP值:

·         ‘YYYY-MM-DD HH:MM:SS’或’YY-MM-DD HH:MM:SS’格式的字串。允许“不严格”语法:任何标点符号都可以用做日期部分或时间部分之间的间割符号。例如,’98-12-31 11:30:45’、’98.12.31 11+30+45’、’98/12/31 11*30*45’和’98@12@31 11^30^45’是等价的。

·         ‘YYYY-MM-DD’或’YY-MM-DD’格式的字串。这里也允许使用“不严格的”语法。例如,’98-12-31’、’98.12.31’、’98/12/31’和’98@12@31’是等价的。

·         ‘YYYYMMDDHHMMSS’或’YYMMDDHHMMSS’格式的没有间割符的字串,假定字串对于日期类型是有意义的。例如,’19970523091528’和’970523091528’被解释为’1997-05-23 09:15:28’,但’971122129015’是不合法的(它有一个没有意义的分钟部分),将变为’0000-00-00 00:00:00’。

·         ‘YYYYMMDD’或’YYMMDD’格式的没有间割符的字串,假定字串对于日期类型是有意义的。例如,’19970523’和’970523’被解释为 ‘1997-05-23’,但’971332’是不合法的(它有一个没有意义的月和日部分),将变为’0000-00-00’。

·         YYYYMMDDHHMMSS或YYMMDDHHMMSS格式的数字,假定数字对于日期类型是有意义的。例如,19830905132800和830905132800被解释为 ‘1983-09-05 13:28:00’。

·         YYYYMMDD或YYMMDD格式的数字,假定数字对于日期类型是有意义的。例如,19830905和830905被解释为’1983-09-05’。

·         函数返回的结果,其值适合DATETIME、DATE或者TIMESTAMP上下文,例如NOW()或CURRENT_DATE。

无效DATETIME、DATE或者TIMESTAMP值被转换为相应类型的“零”值(‘0000-00-00 00:00:00’、’0000-00-00’或者00000000000000)。

对于包括日期部分间割符的字串值,如果日和月的值小于10,不需要指定两位数。’1979-6-9’与’1979-06-09’是相同的。同样,对于包括时间部分间割符的字串值,如果时、分和秒的值小于10,不需要指定两位数。’1979-10-30 1:2:3’与’1979-10-30 01:02:03’相同。

数字值应为6、8、12或者14位长。如果一个数值是8或14位长,则假定为YYYYMMDD或YYYYMMDDHHMMSS格式,前4位数资料表示年。如果数字 是6或12位长,则假定为YYMMDD或YYMMDDHHMMSS格式,前2位数资料表示年。其它数字被解释为仿佛用零填充到了最近的长度。

指定为非限定符字串的值使用给定的长度进行解释。如果字串为8或14字元长,前4位数资料表示年。否则,前2位数资料表示年。从左向右解释字串内出现的各部分,以发现年、月、日、小时、分和秒值。这说明不应使用少于6字元的字串。例如,如果您指定’9903’,认为它资料表示1999年3月,MySQL将在您的资料表内插入一个“零”日期值。这是因为年和月值是99和03,但日部分完全丢失,因此该值不是一个合法的日期。但是,可以明显指定一个零值来代资料表缺少的月或日部分。例如,可以使用’990300’来插入值’1999-03-00’。

在一定程度上,可以将一个日期类型的值分配给一个不同的日期类型。但是,值可能会更改或丢失一些讯息:

·         如果您为一个DATETIME或TIMESTAMP对像分配一个DATE值,结果值的时间部分被设置为’00:00:00’,因为DATE值未包含时间讯息。

·         如果您为一个DATE对像分配一个DATETIME或TIMESTAMP值,结果值的时间部分被删除,因为DATE值未包含时间讯息。

·         记住尽管可以使用相同的格式指定DATETIME、DATE和TIMESTAMP值,不同类型的值的范围却不同。例如,TIMESTAMP值不能早于1970或晚于2037。这说明一个日期,例如’1968-01-01’,虽然对于DATETIME或DATE值是有效的,但对于TIMESTAMP值却无效,如果分配给这样一个对像将被转换为0。

当指定日期值时请注意某些问题:

·         指定为字串的值允许的非严格格式可能会欺骗。例如,值’10:11:12’由于‘:’间割符看上去可能像时间值,但如果用于日期上下文值则被解释为年’2010-11-12’。值’10:45:15’被转换为’0000-00-00’因为’45’不是合法月。

·         在非严格模式,MySQL伺服器只对日期的合法性进行基本检查:年、月和日的范围分别是1000到9999、00到12和00到31。任何包含超出这些范围的部分的日期被转换成’0000-00-00’。请注意仍然允许您保存非法日期,例如’2002-04-31’。要想确保不使用严格模式时日期有效,应检查应用程式。

在严格模式,非法日期不被接受,并且不转换。

详细讯息参见5.3.2节,“SQL伺服器模式”

·         包含两位年值的日期会令人模糊,因为世纪不知道。MySQL使用以下规则解释两位年值:

o        00-69范围的年值转换为2000-2069。

o        70-99范围的年值转换为1970-1999。

Comments are closed.