我有date
列,其类型为varchar(40)
我想将其转换为datetime
如果以下命令正确转换为datetime
UPDATE `table`
SET `date` = str_to_date( `date`, '%d-%m-%Y' );
该表有数千条记录。例如,date
对于一条记录
10/21/2016 15:02
答案 0 :(得分:1)
两件事:
首先,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 t\G
CREATE TABLE `t` (
`v` datetime DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4