Mysql
 sql >> Database >  >> RDS >> Mysql

Aggiorna le righe duplicate con l'ID trovato duplicato

Questa query restituirà tutti gli ID duplicati con un elenco separato da virgole di ID che condividono lo stesso nome:

select
  t1.id,
  group_concat(t2.id)
from
  tablename t1 inner join tablename t2
  on t1.id<>t2.id and t1.name=t2.name
group by
  t1.id

e questa query aggiornerà la descrizione:

update tablename inner join (
  select
    t1.id,
    group_concat(t2.id) dup
  from
    tablename t1 inner join tablename t2
    on t1.id<>t2.id and t1.name=t2.name
  group by
    t1.id
  ) s on tablename.id = s.id
set
  description = concat('duplicate id in (', s.dup, ')')

si prega di vedere un violino funzionante qui .