如何将数据库中的 Unix 时间戳数据更改为 MySQL 时间戳? [重复]

问题描述 投票:0回答:1

总的来说,我对数据库还很陌生。

我创建了一个,并让我的应用程序获取当前时间作为 Unix 时间戳并存储在

time_stamp int(11) NOT NULL
中。

现在我意识到那是多么愚蠢,但我不想丢失我的数据。

我可以在 MySQL 命令框中使用 UPDATE 语句将所有这些

INT
更改为 MySQL
TIMESTAMP
吗?


或者,我有数据库转储,所以我想我也可以使用 PhpMyAdmin 重新定义列(这似乎将我所有的 INT 设置为“00-00-0000 00:00:00”),然后删除表内容,全局编辑 SqlDump 并导入它。

但是,如果我这样做,我该如何编辑转储? 这是其中的几行...

INSERT INTO `activity` (`badge_number`, `time_stamp`, `activity`, `bar_code`, `rfid_tag`)   
VALUES (0, 1350388291, 'login', '', ''), (0,1350388433, 'logout', '', ''),

那么,

UPDATE ACTIVITY SET time_stamp = <what?> WHERE <what?>
mysql sql timestamp unix-timestamp
1个回答
3
投票

尝试其中一个

ALTER TABLE activity CHANGE time_stamp time_stamp VARCHAR(19);
UPDATE activity 
   SET time_stamp = FROM_UNIXTIME(time_stamp);
ALTER TABLE activity CHANGE time_stamp time_stamp TIMESTAMP;

这里是SQLFiddle演示

ALTER TABLE activity ADD COLUMN time_stamp2 TIMESTAMP;
UPDATE activity 
   SET time_stamp2 = FROM_UNIXTIME(time_stamp);
ALTER TABLE activity DROP COLUMN time_stamp;
ALTER TABLE activity CHANGE time_stamp2 time_stamp TIMESTAMP;

这里是SQLFiddle演示

注意: 在继续更新之前,请确保您有表/数据库的可靠备份。以防万一。

© www.soinside.com 2019 - 2024. All rights reserved.