登录
首页 >  数据库 >  MySQL

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

来源:tutorialspoint

时间:2023-08-25 22:19:14 247浏览 收藏

小伙伴们对数据库编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《字符串或数字中应该有多少位数字才能被 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。

以上就是本文的全部内容了,是否有顺利帮助你解决问题?若是能给你带来学习上的帮助,请大家多多支持golang学习网!更多关于数据库的相关知识,也可关注golang学习网公众号。

声明:本文转载于:tutorialspoint 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>