mysql - 具有连接表关系的事件管理

标签 mysql ruby-on-rails ruby-on-rails-3 activerecord activeadmin

我正在配置事件管理。除了连接表之外,一切都在运行,连接表将杂志资源与关键字资源连接起来。一本杂志由多个关键字定义,一个关键字可以定义多本杂志。

我有两个模型:

### models/magazine.rb

class Magazine < ActiveRecord::Base
    attr_accessible :colour, :cover_alt, :description, :number, :short, :title_id

    has_and_belongs_to_many :keywords, :join_table => "magazines_keywords" 
    belongs_to :title, :class_name => "Keyword", :foreign_key => "title_id"
end


### models/keywords.rb

class Keyword < ActiveRecord::Base
  attr_accessible :word, :description

  has_and_belongs_to_many :magazines, :join_table => "magazines_keywords"
end

和一个连接表:

### models/magazines_keyword.rb
class MagazinesKeyword < ActiveRecord::Base
  attr_accessible :magazine_id, :keyword_id

  belongs_to :magazine
  belongs_to :keyword
end

此设置适用于我的 Rails 应用程序的 View ,并且我的 AA 杂志资源的索引和显示部分可以正常工作,但表单(用于新建和编辑)不起作用:

ActiveAdmin.register Magazine do
    menu :priority => 1

    form do |f|
        f.semantic_errors *f.object.errors.keys
        f.inputs "Magazine Details" do
            f.input :title_id, :label => 'Title', :as => :select, :collection => Keyword.all.map{ |u| ["#{u.word.capitalize}", u.id] }
            f.inputs :magazines_keywords do
                f.has_many : magazines_keywords do |s|
                    s.input :keyword, :as => :select, :multiple => true, :collection => MagazinesKeyword.all.map { |u| ["#{u.keyword.word.capitalize}", u.id] }
                end
            end
        end
        f.actions
    end

    show do
        panel "Magazine Details" do
            attributes_table_for magazine do
                row "Keywords", :keyword do |m|
                    m.keywords.map { |d| d.word }.join(", ").html_safe
                end
            end
        end
        active_admin_comments
    end
end

运行应用程序时,我得到 NoMethodError in Admin/magazines#edit

哪里/active_admin/resource/edit.html.arb line #1加薪undefined method 'klass' for nil:NilClass

我可以使用以下方式显示表单部分中的所有关键字:

f.input :magazines_keywords, :as => :check_boxes, :multiple => true, :collection => MagazinesKeyword.all.map{ |u| ["#{u.keyword.word.capitalize}", u.id] }

但是当我尝试编写它们时,它不起作用。编辑值也不起作用。

我哪里遗漏了什么?我怎样才能让它工作?

****更新****

经过一些工作,我得到了以下解决方案:

form do |f|
    f.semantic_errors *f.object.errors.keys
    f.inputs "Saft Details" do
        f.input :title_id, :label => 'Title', :as => :select, :collection => Keyword.all.map{ |u| ["#{u.word.capitalize}", u.id] }
        f.input :keywords, :as => :check_boxes, :input_html => {:multiple => true}
    end
    f.actions
end

按照建议:

f.input :keywords, :as => :check_boxes, :input_html => {:multiple => true} do
    f.has_many :keywords do |s|
        s.input :keyword, :collection => Keyword.all.map { |kw| ["#{kw.word.capitalize}", kw.id] }
        end
end

使用这两种解决方案,我都可以编写新的杂志条目并将关联写入连接表,不幸的是它显示 #<Keyword:0x10c858858>以形式而非文字。我错过了什么?

最佳答案

ActiveAdmin 非常聪明,能够理解您想要做什么。因此,您应该忽略 MagazinesKeyword 并直接进入 Keyword 模型。 所以你应该改变这个:

f.has_many :magazines_keywords do |s|
  s.input :keyword, :as => :select, :multiple => true, :collection => MagazinesKeyword.all.map { |u| ["#{u.keyword.word.capitalize}", u.id] }
end

这样:

f.has_many :keywords do |s|
  s.input :keyword, :as => :select, :multiple => true, :collection => Keyword.all.map { |kw| ["#{kw.word.capitalize}", kw.id] }
end

活跃管理员将自行处理MagazinesKeyword

关于mysql - 具有连接表关系的事件管理,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49068308/

相关文章:

ruby-on-rails - rails 模型 has_many 本身

ruby-on-rails - 如果 rails html.erb 中的每个条件中的任何一个为真,如何仅显示一次 <p>

SQL 查询检查第一个表中的列或查找第二个表中的行

JavaScript 在生产环境中不起作用

ruby-on-rails - 尝试安装 pg gem 时找不到 'libpq-fe.h header

javascript - html表单字段在提交表单之前从sql数据库获取内容?

php - 以与 MySQL 相同的方式比较 PHP 中的字符串

ruby-on-rails - 如何在子目录中部署Rails 3.1应用

php - 计算 where 子句上每个值的 sql 结果

mysql - MySQL Workbench 导出的 CREATE 脚本在另一台计算机上有语法错误