Миграция Rails заблокирована из-за «ограничения внешнего ключа» - PullRequest
0 голосов
/ 09 марта 2019

Когда я пытаюсь запустить относительно простую миграцию рельсов для удаления столбца:

class Removetopicsfromquestions < ActiveRecord::Migration[5.2]
  def change
    change_table :questions do |t|
      t.remove :topic_id
    end
  end
end

Сбой из-за "ограничения внешнего ключа":

rails aborted!
StandardError: An error has occurred, this and all later migrations canceled:

SQLite3::ConstraintException: foreign key constraint failed: DROP TABLE "questions"
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/statement.rb:108:in `step'
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/statement.rb:108:in `block in each'
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/statement.rb:107:in `loop'
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/statement.rb:107:in `each'
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/database.rb:152:in `map'
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/database.rb:152:in `block in execute'
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/database.rb:95:in `prepare'
/usr/local/rvm/gems/ruby-2.4.1/gems/sqlite3-1.3.13/lib/sqlite3/database.rb:137:in `execute'
etc...

И для справкикак выглядит таблица в данный момент:

create_table "questions", force: :cascade do |t|
    t.integer "topic_id"
    t.string "name"
    t.text "explanation"
    t.boolean "published", default: true
    t.string "usage", default: "Free Quiz", null: false
    t.datetime "created_at", null: false
    t.datetime "updated_at", null: false
    t.string "variant", default: "fill", null: false
    t.string "correct"
    t.string "alt_one"
    t.string "alt_two"
    t.string "alt_three"
    t.string "editor"
    t.boolean "accepted"
    t.string "reference"
    t.text "context"
    t.string "questionable_type"
    t.integer "questionable_id"
    t.index ["questionable_type", "questionable_id"], name: "index_questions_on_questionable_type_and_questionable_id"
  end

Есть идеи, что я делаю неправильно?

1 Ответ

0 голосов
/ 09 марта 2019

Я предполагаю, что у вас есть что-то подобное в нижней части вашей схемы?

add_foreign_key "questions", "topics"

Rails не может удалить этот столбец из таблицы, так как добавлен внешний ключ. Попробуйте это вместо этого в вашем файле миграции:

def change
  remove_reference :questions, :topic, index: true, foreign_key: true
end
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...