问题描述
||
我正在创建一个更改日志数据库,该数据库与我的活动数据库完全相同,只是它的末尾有一个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();