Ruby on rails Can';t运行heroku rake数据库:迁移

Ruby on rails Can';t运行heroku rake数据库:迁移,ruby-on-rails,ruby,postgresql,heroku,ruby-on-rails-5,Ruby On Rails,Ruby,Postgresql,Heroku,Ruby On Rails 5,我的应用程序在开发中工作得很好,但当我尝试在Heroku上提供它时,我得到以下错误: PG::UndefinedTable: ERROR: relation "users" does not exist : CREATE TABLE "games" ("id" serial primary key, "title" character varying, "image" character varying, "description" character varying, "user_id" i

我的应用程序在开发中工作得很好,但当我尝试在Heroku上提供它时,我得到以下错误:

PG::UndefinedTable: ERROR:  relation "users" does not exist
: CREATE TABLE "games" ("id" serial primary key, "title" character varying, "image" character varying, "description" character varying, "user_id" integer, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL, CONSTRAINT "fk_rails_de9e6ea7f7"
FOREIGN KEY ("user_id")
  REFERENCES "users" ("id")
)
当我尝试运行
heroku-rake-db:drop、heroku-rake-db:reset、heroku-rake-db:migrate
时,会出现该错误

这是我的数据库模式:

ActiveRecord::Schema.define(version: 20170305021159) do

  create_table "comments", force: :cascade do |t|
    t.string   "body"
    t.integer  "user_id"
    t.integer  "game_id"
    t.datetime "created_at", null: false
    t.datetime "updated_at", null: false
    t.index ["game_id"], name: "index_comments_on_game_id"
    t.index ["user_id"], name: "index_comments_on_user_id"
  end

  create_table "games", force: :cascade do |t|
    t.string   "title"
    t.string   "image"
    t.string   "description"
    t.integer  "user_id"
    t.datetime "created_at",         null: false
    t.datetime "updated_at",         null: false
    t.string   "image_file_name"
    t.string   "image_content_type"
    t.integer  "image_file_size"
    t.datetime "image_updated_at"
    t.index ["user_id"], name: "index_games_on_user_id"
  end

  create_table "users", force: :cascade do |t|
    t.string   "email",                  default: "", null: false
    t.string   "encrypted_password",     default: "", null: false
    t.string   "reset_password_token"
    t.datetime "reset_password_sent_at"
    t.datetime "remember_created_at"
    t.integer  "sign_in_count",          default: 0,  null: false
    t.datetime "current_sign_in_at"
    t.datetime "last_sign_in_at"
    t.string   "current_sign_in_ip"
    t.string   "last_sign_in_ip"
    t.datetime "created_at",                          null: false
    t.datetime "updated_at",                          null: false
    t.index ["email"], name: "index_users_on_email", unique: true
    t.index ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true
  end

end
这是我的环境:

Rails version             5.0.2
Ruby version              2.3.1-p112 (x86_64-linux-gnu)
RubyGems version          2.5.1
Rack version              2.0.1
JavaScript Runtime        Node.js (V8)
这个项目是用rails 4创建的,后来更新为rails 5

如何在Heroku中迁移数据库


感谢阅读。

推荐的方法是运行

heroku rake db:schema:load
当它将工作模式从开发数据库加载到生产服务器时。不建议使用迁移,这来自官方指南

迁移虽然强大,但并不是权威的来源 用于数据库架构。该角色属于db/schema.rb或 活动记录通过检查数据库生成的SQL文件。他们 不是为编辑而设计的,它们只是表示当前状态 这是数据库的一部分


建议的方法是运行

heroku rake db:schema:load
当它将工作模式从开发数据库加载到生产服务器时。不建议使用迁移,这来自官方指南

迁移虽然强大,但并不是权威的来源 用于数据库架构。该角色属于db/schema.rb或 活动记录通过检查数据库生成的SQL文件。他们 不是为编辑而设计的,它们只是表示当前状态 这是数据库的一部分


您是否尝试运行
heroku rake db:schema:load
在heroku上直接加载您的模式?heroku rake db:schema:load,工作正常;你知道会发生什么吗@Icemango,d我做了一个解释性的回答。你是否试过运行
heroku rake db:schema:load
直接在heroku上加载你的模式?heroku rake db:schema:load,工作正常;你知道会发生什么吗@Icemango,d我做了解释性的回答。谢谢你的帮助!实际上,我认为您需要heroku运行rake db:schema:load。我相信heroku rake的
语法已经被弃用了。谢谢你的帮助!实际上,我认为您需要heroku运行rake db:schema:load
。我认为heroku-rake的
语法已经被弃用了。