提问者:小点点

Mysql STR_TO_DATE在不同环境中给出不一致的结果


使用STR_TO_DATE函数,我在两个不同的Docker映像上遇到了不一致的行为。 一个在ubuntu上运行,另一个在我的Mac上运行。

在Linux上:

SELECT STR_TO_DATE('203005','%H%i%s');
+--------------------------------+
| STR_TO_DATE('203005','%H%i%s') |
+--------------------------------+
| 20:30:05                       |
+--------------------------------+

SELECT VERSION();
+-----------+
| VERSION() |
+-----------+
| 8.0.19    |
+-----------+

在我的Mac上:

SELECT STR_TO_DATE('203005','%H%i%s');
+--------------------------------+
| STR_TO_DATE('203005','%H%i%s') |
+--------------------------------+
| NULL                           |
+--------------------------------+

SELECT VERSION();
+-----------+
| VERSION() |
+-----------+
| 8.0.12    |
+-----------+

show warnings; 
+---------+------+-------------------------------------------------------------+
| Level   | Code | Message                                                     |
+---------+------+-------------------------------------------------------------+
| Warning | 1411 | Incorrect datetime value: '203005' for function str_to_date |
+---------+------+-------------------------------------------------------------+

都在Docker映像上运行Mysql:

      docker_container:
        name: mysql
        image: mysql:8.0

共1个答案

匿名用户

如果您有一个不完整的datetime值(在您的示例中,没有日期)并且设置了SQL模式no_zero_date(请参阅手册),str_to_date将返回null。 例如:

SET @@sql_mode = ''
;
SELECT @@sql_mode, STR_TO_DATE('203005','%H%i%s') AS date
;
SET @@sql_mode = 'NO_ZERO_IN_DATE'
;
SELECT @@sql_mode, STR_TO_DATE('203005','%H%i%s') AS date
;
SET @@sql_mode = 'NO_ZERO_DATE'
;
SELECT @@sql_mode, STR_TO_DATE('203005','%H%i%s') AS date

输出:

@@sql_mode          date
                    20:30:05
NO_ZERO_IN_DATE     20:30:05
NO_ZERO_DATE        null

dbfiddle上的演示