如何在我的数据库中将Unix时间戳数据更改为MySql时间戳?

时间:2013-12-06 03:31:36

标签: mysql sql timestamp unix-timestamp

我对数据库一般都很陌生。

我创建了一个,并让我的应用程序将当前时间作为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?>

提前感谢您的帮助。

1 个答案:

答案 0 :(得分:2)

尝试

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 演示

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