【发布时间】:2017-11-29 15:41:31
【问题描述】:
我最初使用 PostgreSQL 开发我的 rails 5 应用程序。由于托管方面的一些问题,我在完成所有开发后不得不切换到 MariaDB。
我正在尝试进行更新,以从我的购物车中添加对管理员的引用。这是我的迁移:
class AddAdminRefToCart < ActiveRecord::Migration[5.1]
def change
add_reference :carts, :admin, foreign_key: true
end
end
当我跑步时
rake db:migrate
我收到此错误:
== 20171129152942 AddAdminRefToCart: migrating ================================
-- add_reference(:carts, :admin, {:foreign_key=>true})
rake aborted!
StandardError: An error has occurred, all later migrations canceled:
Column `admin_id` on table `carts` has a type of `bigint(20)`.
This does not match column `id` on `admins`, which has type `int(11)`.
To resolve this issue, change the type of the `admin_id` column on `carts` to be :integer. (For example `t.integer admin_id`).
错误是有道理的,但我不确定解决问题的正确方法。有人可以就我应该如何编写迁移提供一些指导吗?提前致谢!
【问题讨论】:
标签: ruby-on-rails ruby postgresql ruby-on-rails-5 mariadb