Mysql STR_TO_DATE дает противоречивый результат в разных средах - PullRequest
3 голосов
/ 21 июня 2020

Я столкнулся с противоречивым поведением двух разных изображений Docker с функцией STR_TO_DATE. При запуске на Ubuntu, а другой на моем Ma c.

On 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    |
+-----------+

На моем Ma c:

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 |
+---------+------+-------------------------------------------------------------+

Оба работают Mysql на Docker образе:

      docker_container:
        name: mysql
        image: mysql:8.0

1 Ответ

3 голосов
/ 21 июня 2020

STR_TO_DATE вернет NULL, если у вас есть неполное значение datetime (в вашем случае нет даты) и установлено 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

Демонстрация на dbfiddle

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...