MySQL 无法解析数字和字符串作为日期,因为它没有分隔符。
若字符串或数字遵循YYYYMMDDHHMMSS 或者 YYMMDDHHMMSS 格式,且不含任何分隔符,但可将其解读为日期,则 MySQL 会将该字符串解读为有效的日期。
以下示例提供了有效和无效的日期 −
mysql> Select Timestamp(20171022040536);
+---------------------------+
| Timestamp(20171022040536) |
+---------------------------+
| 2017-10-22 04:05:36 |
+---------------------------+
1 row in set (0.00 sec)
mysql> Select Timestamp('20171022040536');
+-----------------------------+
| Timestamp('20171022040536') |
+-----------------------------+
| 2017-10-22 04:05:36 |
+-----------------------------+
1 row in set (0.00 sec)
mysql> Select Timestamp('171022040536');
+---------------------------+
| Timestamp('171022040536') |
+---------------------------+
| 2017-10-22 04:05:36 |
+---------------------------+
1 row in set (0.00 sec)上述查询展示了 MySQL 可解读为日期值的有效字符串和数字示例。
mysql> Select Timestamp('20171022048536');
+-----------------------------+
| Timestamp('20171022048536') |
+-----------------------------+
| NULL |
+-----------------------------+
1 row in set, 1 warning (0.00 sec)上述查询为无效字符串的示例。MySQL 返回 NULL,因为字符串的分钟部分包含错误值 (85)。
mysql> Select Timestamp('20171322040536');
+-----------------------------+
| Timestamp('20171322040536') |
+-----------------------------+
| NULL |
+-----------------------------+
1 row in set, 1 warning (0.00 sec)在上述查询中,MySQL 返回 NULL,因为字符串的月份部分包含错误值 (13)。
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 编程
C++
C#
MongoDB
MySQL
JavaScript
PHP