字符串或数字中应该有多少位数字才能被 MySQL 指定为日期值?

字符串或数字中应该有多少位数字才能被 MySQL 指定为日期值?

虽然将年份视为 4 位数字值,但 MySQL 需要字符串或数字中至少有 8 位数字才能将其指定为日期值。在这种情况下,如果我们还想存储微秒,那么该值最多可以为 20 位数字。

mysql> Select TIMESTAMP(‘20171022040536.100000’);
+———————————–+
| TIMESTAMP(‘20171022040536100000’) |
+———————————–+
| 2017-10-22 04:05:36.100000 |
+———————————–+
1 row in set, 1 warning (0.00 sec)

登录后复制

上面的查询采用 20 位数字字符串作为 TIMESTAMP 值。最后 6 位数字表示微秒。

mysql> Select TIMESTAMP(20171022);
+———————+
| TIMESTAMP(20171022) |
+———————+
| 2017-10-22 00:00:00 |
+———————+
1 row in set (0.00 sec)

登录后复制

上面的查询采用 8 位数字字符串作为 TIMESTAMP 值。

mysql> Select TIMESTAMP(201710);
+——————-+
| TIMESTAMP(201710) |
+——————-+
| NULL |
+——————-+
1 row in set, 1 warning (0.00 sec)

登录后复制

上面的查询返回 NULL,因为数字的位数小于 8。

相反,当将年份视为 2 位数字时,字符串或数字中至少需要 6 位数字MySQL 将其指定为日期值。在这种情况下,如果我们还想存储微秒,那么该值最多可以为 18 位数字。

mysql> Select TIMESTAMP(171022);
+———————+
| TIMESTAMP(171022) |
+———————+
| 2017-10-22 00:00:00 |
+———————+
1 row in set (0.00 sec)

登录后复制

上面的查询采用 6 位数字字符串作为 TIMESTAMP 值。

mysql> Select TIMESTAMP(‘171022040536.200000’);
+———————————-+
| TIMESTAMP(‘171022040536.200000’) |
+———————————-+
| 2017-10-22 04:05:36.200000 |
+———————————-+
1 row in set (0.00 sec)

登录后复制

上面的查询采用 18 位数字字符串作为 TIMESTAMP 值。点 (.) 后的最后 6 位数字表示微秒。

mysql> Select TIMESTAMP(1710);
+—————–+
| TIMESTAMP(1710) |
+—————–+
| NULL |
+—————–+
1 row in set, 1 warning (0.00 sec)

登录后复制

上面的查询返回 NULL,因为位数小于 6。

以上就是字符串或数字中应该有多少位数字才能被 MySQL 指定为日期值?的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!

上一篇 我们如何将 CHAR_LENGTH() 函数与 MySQL WHERE 子句一起使用?
下一篇 使用 MySQL LIMIT、OFFSET 进行分页?
三掌柜

三掌柜

这个人很懒,什么都没有留下~

本月创作热力图