Mysql 将varchar(40)转换为datetime列

Mysql 将varchar(40)转换为datetime列,mysql,sql,Mysql,Sql,我有date列,它的类型是varchar(40) 我想将其转换为datetime UPDATE `table` SET `date` = str_to_date( `date`, '%d-%m-%Y' ); 请让我知道下面的命令是否正确地转换为datetime UPDATE `table` SET `date` = str_to_date( `date`, '%d-%m-%Y' ); 这张表有数千条记录。例如,date对于一条记录有值10/21/2016 15:02,两件事: 首先,str_

我有
date
列,它的类型是
varchar(40)
我想将其转换为
datetime

UPDATE `table`
SET `date` = str_to_date( `date`, '%d-%m-%Y' );
请让我知道下面的命令是否正确地转换为
datetime

UPDATE `table`
SET `date` = str_to_date( `date`, '%d-%m-%Y' );
这张表有数千条记录。例如,
date
对于一条记录有值
10/21/2016 15:02
,两件事:

首先,str_to_date()格式必须与输入字符串的格式匹配。如果输入字符串为
10/21/2016 15:02
,则格式为
%m/%d/%Y%H:%i

请参见此处的格式代码参考:

其次,使用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