使用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
如果您有一个不完整的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上的演示