3

mysql の重複キー更新挿入で増分更新を行う方法はありますか?

エラーのある例:

insert into blah (user_id, prefix, email_id, field, source) 
select user_id, substring(name, 1, 3), contact_email_id, 2, source from address_book 
on duplicate key update source = source + values(source);

ERROR 1052 (23000): Column 'source' in field list is ambiguous
4

2 に答える 2

1

テーブルの前に列名、つまりblah.source、address_book.sourceを付けるとどうなりますか?

于 2010-12-13T18:18:31.593 に答える
1

いいえsource = source + values(source);
、 ソース テーブルblahが に含まれていないため指定できませんselect。エイリアスを使用しても修正されません。

回避策は使用されますleft join

insert into blah (user_id, prefix, email_id, field, source) 
select 
  ab1.user_id, substring(ab1.name, 1, 3), ab1.contact_email_id, 2, 
  if(ab2.source, ab1.source+ab2.source, ab1.source)
from 
  address_book ab1
left join
  blah1 as ab2
on 
  ab1.user_id=ab2.user_id
on duplicate key 
update source = values(source); 
/* values(source) = ab1.source+ab2.source if duplicate found */

1:N関係に注意

于 2010-12-13T21:13:40.793 に答える