2

并提前感谢这里提供的任何帮助。实际上,我是 Rails 开发和 stackoverflow 的新手。我正在创建多对多的关系,并且在一些基础知识方面遇到了麻烦。我想做一个用户和组的关系。

楷模:

    class User < ActiveRecord::Base
      attr_accessible :name
      has_and_belongs_to_many :groups
    end

    class Group < ActiveRecord::Base
      attr_accessible :name
      has_and_belongs_to_many :users
    end

db/migrate create_groups_users_join

class CreateGroupsUsersJoin < ActiveRecord::Migration
  def self.up
    create_table 'groups_users', :id => false do |t|
      t.column 'group_id', :integer
      t.column 'user_id', :integer
     end
   end
 def self.down
   drop_table 'groups_users'
 end
end

我使用此代码在我的用户表单上创建了一个下拉列表。

真 }) %>

控制器

def edit
  @user = User.find(params[:id])
  @groups = Group.all
  ...
end
  def new
  @user = User.new
  @groups = Group.all
  ...
end

我现在迷失了要添加到控制器以更新创建/编辑/更新的连接表的内容。谁能解释我需要改变什么才能做到这一点?谢谢你。

这是我现在得到的错误输出:

 {"utf8"=>"✓",
    "authenticity_token"=>"pgyajCT23qQVMuS+MQgG6E7M7Q8AWjfGaYbe3q7QDSA=",
    "group"=>{"group_id"=>"1"},
    "user"=>{"name"=>"ymudfg"},
    "commit"=>"Create User"}
4

3 回答 3

3

您可以通过在控制器中执行以下操作将用户添加到组:

   user = User.find(params[:uid])
   group = Group.find(params[:gid])

   group.users <<  user  #Adding user to group

为用户分配组:

   user.groups << group

编辑:根据您的评论

  class UsersController < ApplicationController
    def new
      @user = User.new
      @group = Group.all
    end

    def create
      @user = User.new(params[:user])
      @group = Group.find(params[:group][:group_id]) # As per log
      if @user.save
        @group.users << @user
      else
        render :new
      end
    end

    #Similarly you can implement edit
  end
于 2013-01-11T14:12:18.300 回答
0

用户和组之间的关联由 rails 自动处理,这就是您添加has_and_belongs_to_many.

如果要将用户添加到组中,可以执行以下操作:

@group.users.create(params[:user])

另一边你可以做:

@user.groups.create(params[:group])

要查找您可以执行的用户组:

@user.groups.find(params[:id])

于 2013-01-11T14:14:45.500 回答
0

现在最好使用:has many through associations比 has_and_belongs_to_many

于 2016-12-29T23:20:18.327 回答