mysql插入多行结果集,mysql将多行查询结果插入表

I came across a scenario where I need to "upgrade" a table with data I obtain from another query. I am adding missing values so I will need to insert, but I cant seem to get it right.

The destination table is the following

CREATE TABLE `documentcounters` (

`UID` int,

`DataChar`,

`SeqNum` ,

`LastSignature`,

`DocumentType`,

`SalesTerminal`,

`Active`,

PRIMARY KEY (`UID`)

) ENGINE=InnoDB

and I am trying to do something like

INSERT INTO documentcounters

SELECT Q1.in_headers, -1,NULL, 17,0,0 FROM

(SELECT DISTINCT(DocumentSeries) as in_headers FROM transactionsheaders )AS Q1

LEFT JOIN

(SELECT DISTINCT(DataChar) as in_counters FROM documentcounters)AS Q2

ON Q1.in_headers=Q2.in_counters WHERE Q2.in_counters IS NULL;

I left UID out because I want the insert statement to create it, but I get a "Column count doesn't match" which makes sense (darn!)

Doing something like

INSERT INTO `documentcounters`

(`DataChar`,`SeqNum`,`LastSignature`,`DocumentType`,`SalesTerminal`,`Active`)

VALUES

(

(SELECT Q1.in_headers FROM

(SELECT DISTINCT(DocumentSeries) as in_headers FROM transactionsheaders )AS Q1

LEFT JOIN

(SELECT DISTINCT(DataChar) as in_counters FROM documentcounters)AS Q2

ON Q1.in_headers=Q2.in_counters WHERE Q2.in_counters IS NULL),-1,NULL,17,0,0

);

yields a "Subquery returns more than 1 row" error.

Any ideas how I can make this work?

Cheers

解决方案INSERT INTO `documentcounters`

(`DataChar`,`SeqNum`,`LastSignature`,`DocumentType`,`SalesTerminal`,`Active`)

SELECT Q1.in_headers, -1,NULL, 17,0,0 FROM

(SELECT DISTINCT(DocumentSeries) as in_headers FROM transactionsheaders )AS Q1

LEFT JOIN

(SELECT DISTINCT(DataChar) as in_counters FROM documentcounters)AS Q2

ON Q1.in_headers=Q2.in_counters WHERE Q2.in_counters IS NULL;

This will work if UID is defined as auto_increment.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值