详情如下
select date('2014-05-16T11:13:57+08:00');
+-----------------------------------+
| date('2014-05-16T11:13:57+08:00') |
+-----------------------------------+
| 2014-05-16 |
+-----------------------------------+
1 row in set, 1 warning (0.02 sec)
mysql> select date('2014-05-16T11:13:57+08:00');
+-----------------------------------+
| date('2014-05-16T11:13:57+08:00') |
+-----------------------------------+
| 2014-05-16 |
+-----------------------------------+
1 row in set, 1 warning (0.00 sec)
mysql> select date('2014-05-16T11:12:57+08:00');
+-----------------------------------+
| date('2014-05-16T11:12:57+08:00') |
+-----------------------------------+
| 2014-05-16 |
+-----------------------------------+
1 row in set, 1 warning (0.00 sec)
mysql> select date_format('2014-05-16T11:13:57+08:00', '%Y-%m-%d %H:%i:%s');
+---------------------------------------------------------------+
| date_format('2014-05-16T11:13:57+08:00', '%Y-%m-%d %H:%i:%s') |
+---------------------------------------------------------------+
| 2014-05-16 11:13:57 |
+---------------------------------------------------------------+
1 row in set, 1 warning (0.03 sec)
mysql> select date_format('2014-05-16T11:13:57+08:00', '%Y-%m-%d %H:%i:%s');
+---------------------------------------------------------------+
| date_format('2014-05-16T11:13:57+08:00', '%Y-%m-%d %H:%i:%s') |
+---------------------------------------------------------------+
| 2014-05-16 11:13:57 |
+---------------------------------------------------------------+
1 row in set, 1 warning (0.00 sec)
本人mysql版本是5.5.19,执行以上sql这个表明mysql是支持w3c日期格式的。
问题出在那儿呢?最后定位到了mysql可能开启严格检查日期模式,执行
set sql_mode=NO_ENGINE_SUBSTITUTION,这个问题就解决了!!!
不过mysql 重启后这个配置就失效了,最好的方法是修改mysql.ini制空
本文详细介绍了在使用MySQL 5.5.19版本时遇到的W3C日期格式不被正确解析的问题,并提供了通过设置SQL_MODE为NO_ENGINE_SUBSTITUTION来解决此问题的方法。同时,文章指出重启MySQL后需修改mysql.ini文件以保持设置。

135

被折叠的 条评论
为什么被折叠?



