Jag är inte säker på exakt vad du vill göra. Men du kan sätta valfri select uttalande i en insert . . . select uttalande och fortfarande använda on duplicate key update . Till exempel:
insert into Table1(field1, field2)
select 1, 2
from table1 t1 join
table2 t2
on t2.id = t1.field_id
where t2.addr = '123456'
on duplicate key update field1 = 1, field2 = 2;