gpt4 book ai didi

mysql - 将 varchar(40) 转换为日期时间列

转载 作者:行者123 更新时间:2023-11-29 07:37:58 25 4
gpt4 key购买 nike

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

请告诉我以下命令是否正确转换为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

请在此处查看格式代码的引用: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

关于mysql - 将 varchar(40) 转换为日期时间列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47861550/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com