从一张表到另一张表的所有行都插入+时间戳记末尾

问题描述

|| 我正在创建一个更改日志数据库,该数据库与我的活动数据库完全相同,只是它的末尾有一个changeate日期字段。 db基本上是一个主键ID,大约是50种其他列的各种数据类型。我在PHP中拥有的脚本是它尝试插入新的id,并且如果它收到重复主键的错误消息,那么它应该获得该行,并使用curdate()调用将其插入到我的备份数据库中作为最终日期值,从我的第一个数据库删除该条目,然后插入新条目。 我已经完成了脚本的所有其他部分,除了必须从第一个表中插入所有内容的部分,还有用于curdate()的额外列。或者,如果有更好的解决方案,当行数相当大时,如果输入重复的主键,则需要插入备份数据库,请分享一下。     

解决方法

        您可以执行INSERT INTO SELECT:
INSERT INTO `backupTable` SELECT *,NOW() FROM `originalTable` WHERE id = \'$id\';
您必须为要复制到备份数据库的条目指定“ 1”。您还必须确保备份表中还没有“ 1”。您可以使用ѭ3来解决这种情况。
REPLACE INTO `backupTable` SELECT *,NOW() FROM `originalTable` WHERE id = \'$id\';
    ,        基本上,您可以使用默认值
CURRENT_TIMESTAMP
创建一个
TIMESTAMP
列。 当您向该表中插入一行时,当前日期/时间将自动插入。 那是你要找的东西吗? 顺便说一句:我建议从源头上解决问题,并确保不会将重复的主键插入到数据表中。 为此,您可以使用
SELECT LAST_INSERT_ID();