gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-02 18:03:32 25 4
gpt4 key购买 nike

我在使用 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

最佳答案

STR_TO_DATE 将返回 NULL 如果您的日期时间值不完整(在您的情况下,没有日期)并且设置了 SQL MODE NO_ZERO_DATE (参见 manual)。例如:

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

Demo on dbfiddle

关于Mysql STR_TO_DATE 在不同环境中给出不一致的结果,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62495355/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com