我对数据库一般都很陌生。
我创建了一个,并让我的应用程序将当前时间作为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?>
提前感谢您的帮助。
答案 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 演示
注意:在继续更新之前,请确保您拥有表/数据库的可靠备份。以防万一。