- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的用户模型与组之间存在 has_many :through 关系。所以用户有很多组,组有很多用户,但我也想由一个用户建立组的所有权,他可以做出最终的决定。
这个想法是 user.groups 是用户所属的所有组,而 user.managed_groups 是用户拥有/管理的所有组。如果有人知道更好的方法来构建它,我们将不胜感激!
下面的代码是我现在的设置。
class UserGroup < ActiveRecord::Base
belongs_to :user
belongs_to :group
end
class Group < ActiveRecord::Base
has_many :user_groups
has_many :members, :through => :user_groups, :class_name => "User", :source => :user
...
class CreateGroups < ActiveRecord::Migration
def change
create_table :groups do |t|
t.integer :user_id, :null => false, :default => 0
t.string :name, :null => false
t.timestamps null: false
end
add_index :groups, :user_id
end
end
class User < ActiveRecord::Base
has_many :user_groups
has_many :groups, :through => :user_groups
has_many :managed_groups ,-> { where(groups: { user_id: @id }) },
through: :user_groups, class_name: "Group", source: :group,
dependent: :destroy
...
@user = FactoryGirl.create :user
@group = FactoryGirl.create :group
@group.user_id = @user.id
@group.members << @user
@group.save
@user.reload
结果是 @user.all_management_groups
完全为 EMPTY,但 @user.groups
则不然。
def all_managed_groups
groups.where("groups.user_id = ?", id)
end
def all_managed_groups
Group.find_by_user_id(id)
end
def all_managed_groups
Group.where("groups.user_id = ?", id)
end
执行上述测试代码后,这些都返回一个空的关联代理
has_many :managed_groups, class_name: "Group",
dependent: :destroy
然后将用户创建的每个新组附加到其托管组
最佳答案
我会选择以下内容:
class Group < ActiveRecord::Base
belongs_to :owner, class_name: "User", foreign_key: "user_id"
has_many :memberships, as: :memberable
has_many :users, through: :memberships
end
class User < ActiveRecord::Base
has_many :memberships
has_many :groups, through: :memberships, source: :memberable, source_type: "Group"
...
end
class Membership < ActiveRecord::Base
belongs_to :user
belongs_to :memberable, polymorphic: true
...
end
如果您需要允许用户将成员(member)资格与任何其他模型相关联,这还可以让成员(member)资格
在未来变得灵活。
希望这有帮助!
class User < ActiveRecord::Base
has_many :managed_groups, foreign_key: "user_id", class: Group
has_many :user_groups
has_many :groups, through: :user_groups
end
class Group < ActiveRecord::Base
belongs_to :user
has_many :user_groups
end
class UserGroup < ActiveRecord::Base
belongs_to :user
belongs_to :group
end
user = User.create(name: "David")
group = Group.create(user_id: user.id, name: "Dayton Ruby")
user.managed_groups => [#<Group id: 1, user_id: 1, name: "Dayton Ruby">]
user.groups => [] (I have not added this user to the UserGroup join table yet)
# adding user as a group member (separate from ownership)
user << groups
user.groups => [#<Group id: 1, user_id: 1, name: "Dayton Ruby">]
如果您希望要求所有者成为群组成员(而不是手动设置),您还可以考虑添加角色
、管理员
等字段添加到您的 UserGroup 连接表中。这将允许您添加逻辑来确定哪个群组成员可以管理该群组。
希望后续内容能有所帮助。
关于mysql - 无法获得适用于 has_many 的动态条件 :through (+ ownership),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35568207/
我有一个具有以下模型的应用程序:- 类别- 子类别- 产品- 产品子类别 我的关系如下: Category has_many :subcategories Subcategory belongs_to
看来 rails 仍然不支持这种类型的关系并抛出 ActiveRecord::HasManyThroughAssociationPolymorphicThroughError 错误。 我该怎么做才能实
我想知道我可以在多大程度上使用 Rails 中的关联。考虑以下因素: class User :provider end class Provider :businesses belongs
我是 Rails 的新手。我想知道我是否需要将 add_index 添加到两个迁移? 我正在尝试定义用户和事件。每个用户可以有多个事件,每个事件可以有多个用户。所以我会做这样的事情: class Us
我有这个: class User :series end class Serial :serials end class Episode < ActiveRecord::Base belong
我一直致力于一个大量使用模型关联的项目,似乎我发现了 has_many 或 has_one through 功能与 :conditions 功能冲突的情况。简而言之,问题是 through 关联为 h
模拟以下情况的最佳方法是什么: Word belongs_to :wordable, :polymorphic => true Phrase has_many :words, :as => :
这似乎是一个典型的问题,但很难搜索。 我想选择用户通过 has_many 拥有的项目和用户通过 has_many through 关联的项目。 考虑以下模型: class User < ActiveR
首先对英语感到抱歉 所以我已经有了“用户 - 帖子”一对多关联,这意味着每个帖子只能有一个作者,现在我想在用户个人资料中添加“最喜欢的帖子”按钮,以及“添加到收藏夹”按钮每个帖子,所以问题是如何实现这
我有一个用户模型,允许用户关注其他用户。每个用户也有很多东西: class User has_many :following, :class_name => 'Followings', :fore
我正在使用 Rails 4.1 和 Ruby 2.1。 一个用户 has_many 辆车,和一辆车 has_many 约会。获取所有用户约会的最简单方法是什么? 理想情况下,我想做这样的事情:user
我想为 has_many/has_many 关系定义一个工厂(我想我做对了)但是我不知道如何为这些创建的工厂的每个对象定义属性。 这是主页,这是交易卡片的列表 我们假设下面的主页 View 是针对登录
我正在努力弄清楚如何实现这个计数。模型是用户、测试、等级 用户 has_many 测试,测试 has_many 成绩。 每个等级都有一个计算分数(strong_pass、pass、fail、stron
我有一个 has many through 关系来定义用户已回答的问题。 如何为用户创建的问题建立关系? 通常你会在用户和问题之间创建一个 has_many 和 belongs_to 关系,但是因为我
例如,在 class Student < ActiveRecord::Base has_many :awards end class Awards < ActiveRecord::Base b
我仍然在尝试如何处理在Ecto中创建/更新has_many, through:关联。我已经重新阅读了José's关于关联以及the docs的帖子,但我仍在努力。 我所拥有的是: 网站/模型/dish
# == Schema Information # # Table name: orders # # id :integer not null, pri
我正在尝试从 EventView.promoter_id = User.id 的用户获取事件,但它无法正常工作。这是我的设置(目前不正确): User has_many :events has_man
我有三门课 TeamMember , Service和ServiceTeamMember 我有 class Service has_many :service_team_members has
我需要列出所有用户及其销售的产品总量及其电子邮件和产品总量, class User :user).group('users.email').sum(:quantity) 关于mysql - 事件记录
我是一名优秀的程序员,十分优秀!