我最初使用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`).
这个错误有道理,但我不确定正确的解决方法。可以有人请给予一些指导,告诉我应该如何编写我的迁移吗?提前感谢!
add_reference
只是add_column
的语法糖,而且还可以可选地添加add_index
和add_foreign_key
。 - jeffdill2