总的来说,我对数据库还很陌生。
我创建了一个,并让我的应用程序获取当前时间作为 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?>
尝试其中一个
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演示
注意: 在继续更新之前,请确保您有表/数据库的可靠备份。以防万一。