12

捆绑安装 gem(gem 'rolify') 后,我使用以下命令生成了文件,

rails g rolify Role User

创建了以下文件,

invoke  active_record
create    app/models/role.rb
invoke    rspec
create      spec/models/role_spec.rb
invoke      factory_girl
create        spec/factories/roles.rb
insert    app/models/role.rb
create    db/migrate/20140425070708_rolify_create_roles
insert  app/models/user.rb
create  config/initializers/rolify.rb

然后,我给了

rake db:migrate

它给了我警告,

[WARN] table 'Role' doesn't exist. Did you run the migration ? Ignoring rolify config.

也没有创建表。我在这里遗漏了什么有什么问题。?这是我的迁移文件,

 class RolifyCreateRoles < ActiveRecord::Migration
    def change
     create_table(:roles) do |t|
      t.string :name
      t.references :resource, :polymorphic => true
      t.timestamps
     end

    create_table(:users_roles, :id => false) do |t|
      t.references :user
      t.references :role
    end

    add_index(:roles, :name)
    add_index(:roles, [ :name, :resource_type, :resource_id ])
    add_index(:users_roles, [ :user_id, :role_id ])
  end
 end

我的版本,

导轨 - 4.1.0 红宝石 - 2.1.1

请任何人帮助我。

提前致谢。

4

2 回答 2

23

这是一个已知的错误rolify;迁移是在没有.rb扩展名的情况下创建的,因此rake db:migrate不会拾取它。

手动重命名您的迁移以添加 .rb 扩展名。改变:

db/migrate/20140425070708_rolify_create_roles

成为:

db/migrate/20140425070708_rolify_create_roles.rb

然后再rake db:migrate一次。

于 2014-04-25T08:43:51.593 回答
1

我对 Rails 5.2.5 和 Rolify 5.0.0 和 Devise 3.5.3 有同样的问题

ActiveRecord::StatementInvalid: Mysql2::Error: Table 'papi_development.roles' doesn't exist: SELECT `roles`.* FROM `roles`

在运行 rake db:migrate 命令之前,我通过在 User 模型中注释掉我的 Devise 行来修复它。

class User < ActiveRecord::Base
  ...
  # devise :database_authenticatable, :registerable, :recoverable, :rememberable, :trackable, :validatable
  ...
end

成功迁移后,我取消了设计线的注释,从那时起一切似乎都正常。

于 2015-12-31T15:47:12.147 回答