summaryrefslogtreecommitdiff
path: root/db/migrate/20170418103908_delete_orphan_notification_settings.rb
blob: c99729b9127504871fcecf97074471120ad8cc9e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
class DeleteOrphanNotificationSettings < ActiveRecord::Migration[4.2]
  DOWNTIME = false

  def up
    execute("DELETE FROM notification_settings WHERE EXISTS (SELECT true FROM (#{orphan_notification_settings}) AS ns WHERE ns.id = notification_settings.id)")
  end

  def down
    # This is a no-op method to make the migration reversible.
    # If someone is trying to rollback for other reasons, we should not throw an Exception.
    # raise ActiveRecord::IrreversibleMigration
  end

  def orphan_notification_settings
    <<-SQL
      SELECT notification_settings.id
      FROM   notification_settings
             LEFT OUTER JOIN namespaces
                          ON namespaces.id = notification_settings.source_id
      WHERE  notification_settings.source_type = 'Namespace'
             AND namespaces.id IS NULL
    SQL
  end
end