MySQL 在从另一个表中选择时插入到具有自动增量的表中

Posted

技术标签:

【中文标题】MySQL 在从另一个表中选择时插入到具有自动增量的表中【英文标题】:MySQL insert into table with auto-increment while selecting from another table 【发布时间】:2013-07-20 09:02:31 【问题描述】:

我有一个带有自增主键的表:

create table rt_table
(
  rtID int PRIMARY KEY AUTO_INCREMENT, 
  rt_user_id BIGINT,               /*user being retweeted*/
  rt_user_name varchar(70),        /*user name of rt_user_id*/
  source_user_id BIGINT,           /*user tweeting rt_user_id*/
  source_user_name varchar(70),    /*user name of source_user_id*/
  tweet_id BIGINT,                 /*fk to table tweets*/

  FOREIGN KEY (tweet_id) references tweets(tweet_id)
);

我希望从另一个表的部分填充此表:

insert into rt_table 
select rt_user_id, (select user_name from users u where u.user_id = t.rt_user_id),
       source_user_id, (select user_name from users u where u.user_id = t.source_user_id),
       tweet_id
  from tweets t
 where rt_user_id != -1;

我收到一个错误,指出列数不匹配,这是因为主键(这是一个自动递增的值,因此不需要设置)。我该如何解决这个问题?

【问题讨论】:

【参考方案1】:

您需要在insert 语句中明确列出列:

insert into rt_table (rt_user_id, rt_user_name, source_user_id, source_user_name, tweet_id)
select rt_user_id, (select user_name from users u where u.user_id = t.rt_user_id),
       source_user_id, (select user_name from users u where u.user_id = t.source_user_id),
       tweet_id
  from tweets t
 where rt_user_id != -1;

另外,我认为使用显式连接比嵌套选择更好:

insert into rt_table (rt_user_id, rt_user_name, source_user_id, source_user_name, tweet_id)
    select t.rt_user_id, u.user_name, t.source_user_id, su.user_name, t.tweet_id
    from tweets t left outer join
         users u
         on t.rt_user_id = u.user_id left outer join
         users su
         on t.source_user_id = su.user_id
    where rt_user_id != -1;

这通常(但不总是)帮助优化器找到最佳查询计划。

【讨论】:

【参考方案2】:

您只需在插入过程中将主键设置为NULL

INSERT INTO rt_table 
SELECT 
  NULL,
  rt_user_id,
  (SELECT 
    user_name 
  FROM
    users u 
  WHERE u.user_id = t.rt_user_id),
  source_user_id,
  (SELECT 
    user_name 
  FROM
    users u 
  WHERE u.user_id = t.source_user_id),
  tweet_id 
FROM
  tweets t 
WHERE rt_user_id != - 1 ;

【讨论】:

以上是关于MySQL 在从另一个表中选择时插入到具有自动增量的表中的主要内容,如果未能解决你的问题,请参考以下文章

如何在从另一个表中提取数据时创建具有约束的表

MySQL nodejs 在从大表中选择数据时崩溃

如何在 MySQL 中使用自动增量字段复制行并插入到同一个表中?

仅当自动增量数据相等时才从另一个表列更新 mysql 列

插入后选择Hibernate

带有Python的Mysql无法插入具有自动增量ID的记录,为啥?