Ruby on rails Can';t运行heroku rake数据库:迁移
我的应用程序在开发中工作得很好,但当我尝试在Heroku上提供它时,我得到以下错误: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
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的语法已经被弃用了。