Acho que este é outro problema de tabela corrompida? Embora isso esteja ocorrendo em uma instância onde é improvável que o banco de dados tenha sido desligado de forma incorreta.
Criei e excluí um emblema sem membros e funcionou normalmente. Adicionei um usuário a um novo emblema e o excluí, e também funcionou normalmente.
Started DELETE "/admin/badges/118" for 71.89.242.121 at 2020-05-28 16:50:04 +0000
Processing by Admin::BadgesController#destroy as */*
Parameters: {"id"=>"118"}
Rendering text template
Rendered text template (Duration: 0.0ms | Allocations: 1)
Completed 500 Internal Server Error in 304ms (ActiveRecord: 0.0ms | Allocations: 114838)
ActiveRecord::InvalidForeignKey (PG::ForeignKeyViolation: ERROR: update or delete on table "badges" violates foreign key constraint "fk_rails_38ea484ed4" on table "user_profiles"
DETAIL: Key (id)=(118) is still referenced from table "user_profiles".
)
/var/www/discourse/vendor/bundle/ruby/2.6.0/gems/rack-mini-profiler-2.0.1/lib/patches/db/pg.rb:72:in `exec_params'
Failed to handle exception in exception app middleware : PG::ForeignKeyViolation: ERROR: update or delete on table "badges" violates foreign key constraint "fk_rails_38ea484ed4" on table "user_profiles"
DETAIL: Key (id)=(118) is still referenced from table "user_profiles".
Mas não tenho certeza de onde procurar ou qual índice tentar recriar.
Não. Parece um bug (menor) que você possa iniciar a exclusão de um emblema se alguém o tiver. Seria melhor se a interface do usuário o impedisse. É totalmente correto que o banco de dados impeça a exclusão e preserve a integridade referencial.