2012-12-18 20:02:00 +02:00
|
|
|
class MoveNoteableCommitToOwnField < ActiveRecord::Migration
|
|
|
|
def up
|
|
|
|
add_column :notes, :commit_id, :string, null: true
|
|
|
|
add_column :notes, :new_noteable_id, :integer, null: true
|
|
|
|
Note.where(noteable_type: 'Commit').update_all('commit_id = noteable_id')
|
2012-12-18 21:06:29 +02:00
|
|
|
|
|
|
|
if ActiveRecord::Base.connection.adapter_name == 'PostgreSQL'
|
2012-12-27 11:03:54 +01:00
|
|
|
Note.where("noteable_type != 'Commit'").update_all('new_noteable_id = CAST (CASE noteable_id WHEN \'\' THEN NULL ELSE noteable_id END AS INTEGER)')
|
2012-12-18 21:06:29 +02:00
|
|
|
else
|
|
|
|
Note.where("noteable_type != 'Commit'").update_all('new_noteable_id = noteable_id')
|
|
|
|
end
|
|
|
|
|
2012-12-18 20:02:00 +02:00
|
|
|
remove_column :notes, :noteable_id
|
|
|
|
rename_column :notes, :new_noteable_id, :noteable_id
|
|
|
|
end
|
|
|
|
|
|
|
|
def down
|
2012-12-19 12:08:27 +02:00
|
|
|
raise ActiveRecord::IrreversibleMigration
|
2012-12-18 20:02:00 +02:00
|
|
|
end
|
|
|
|
end
|