首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >插入未复制的select状态ID

插入未复制的select状态ID
EN

Stack Overflow用户
提问于 2015-03-19 09:09:09
回答 1查看 26关注 0票数 0

当从表A复制到表B时,我有两个结构相同的表,我希望表A、ID和image_name被复制到表B中,其中表A和表B的id是主键,并且自动递增。但是ID在表B中有新的值。

表结构:

代码语言:javascript
复制
 `id` int(11) NOT NULL AUTO_INCREMENT,
  `camera_id` int(11) NOT NULL,
  `name` varchar(20) NOT NULL,
  `plate` varchar(20) NOT NULL,
  `nread` int(11) DEFAULT NULL,
  `datetime` datetime NOT NULL,
  `millisecs` int(3) NOT NULL,
  `nationality` varchar(3) NOT NULL,
  `image_name` varchar(255) DEFAULT NULL,
  `image` mediumblob,
  `checked` int(1) NOT NULL DEFAULT '0',

$sql = "INSERT INTO $newCamTable (plate, nread, datetime, millisecs, nationality, image_name, image) SELECT plate, nread, datetime, millisecs, nationality, image_name, image FROM $camTable WHERE id=\"$tableEntryId\"";
    logit($sql);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-03-19 10:35:34

更改这一行

代码语言:javascript
复制
$sql = "INSERT INTO $newCamTable (plate, nread, datetime, millisecs, nationality, image_name, image) SELECT plate, nread, datetime, millisecs, nationality, image_name, image FROM $camTable WHERE id=\"$tableEntryId\"";

并添加id字段:

代码语言:javascript
复制
$sql = "INSERT INTO $newCamTable (id, plate, nread, datetime, millisecs, nationality, image_name, image) SELECT id,plate, nread, datetime, millisecs, nationality, image_name, image FROM $camTable WHERE id=\"$tableEntryId\"";

这将防止自动增量功能在表'B‘中生成新的ID。

您需要手动管理表B中的ID是唯一的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/29140573

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档