两件事情:
首先,您的str_to_date()格式必须与输入字符串的格式匹配。如果输入字符串为
10/21/2016 15:02,则格式为
%m/%d/%Y%H:%i。
请参阅以下格式代码的参考:https :
//dev.mysql.com/doc/refman/5.7/en/date-and-time-functions.html#function_date-
format
其次,使用UPDATe不会更改列的数据类型,而只会更改varchar字符串的内容。
mysql> create table t (v varchar(50));mysql> insert into t values ('10/21/2016 15:02');mysql> update t set v = str_to_date(v, '%m/%d/%Y %H:%i');mysql> select * from t;+---------------------+| v |+---------------------+| 2016-10-21 15:02:00 |+---------------------+现在它的格式正确,但是仍然是varchar。
mysql> alter table t modify v datetime;mysql> select * from t;+---------------------+| v |+---------------------+| 2016-10-21 15:02:00 |+---------------------+
现在,数据类型已更改。
mysql> show create table tGCREATE TABLE `t` ( `v` datetime DEFAULT NULL) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4



