- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有一个 has_many
主题的群组模型。主题模型 has_many
帖子,我的用户模型只阅读帖子等。我还有一个 users_posts 模型,用于跟踪用户是否已阅读帖子以及他们是否“喜欢”该帖子,它有 :group_id、:user_id 和 :read 和 :liked bool 字段。用户创建一个组并在不同主题下添加帖子。
群组显示操作是;@posts = Group.topics.includes(:posts)
我的问题是何时以及如何向 users_posts 表添加记录?应该是第一次创建帖子时吗?还是仅当用户第一次查看帖子时?
将 user_posts 中的属性添加到@posts 中的每条记录的最佳方法是什么?在我使用虚拟属性的那一刻,这是正确的方法吗?
class Post < ActiveRecord::Base
belongs_to :topic
has_many :users, through: :user_entries
attr_accessor :read, :liked
最佳答案
身份证
首先,您不需要在user_posts
模型/表中使用:group_id
Rails 和关系数据库使用主键
为元素提供唯一的 ID。这意味着无论 post
是否是 group
的成员,您仍然会使用 post_id
foreign key 引用它-
#users_posts
id | user_id | post_id | read | updated | created_at | updated_at
--
属性
add the attributes from
user_posts
to each record in@posts
这样做的方法是将 user_posts
与 User
和 Post
模型相关联 -
#app/models/user.rb
Class User < ActiveRecord::Base
has_many :user_posts
has_many :posts, through: :user_posts
end
#app/models/post.rb
Class Post < ActiveRecord::Base
has_many :user_posts
has_many :users, through: :user_posts
end
这将允许您调用 @user.posts
如果您想为每个post
关联对象附加额外的属性,您需要使用ALIAS SQL join。 ,或 ActiveRecord Association Extension
:
#app/models/post.rb
Class User < ActiveRecord::Base
has_many :user_posts
has_many :posts, through: :user_posts, extend: PostUser
end
#app/models/concerns/post_user.rb
module PostUser
#Load
def load
reads.each do |caption|
proxy_association.target << read
end
end
#Private
private
#Attributes
def captions
return_array = []
through_collection.each_with_index do |through,i|
associate = through.send(reflection_name)
associate.assign_attributes({read: items[i]}) if items[i].present?
return_array.concat Array.new(1).fill( associate )
end
return_array
end
#######################
# Variables #
#######################
#Association
def reflection_name
proxy_association.source_reflection.name
end
#Foreign Key
def through_source_key
proxy_association.reflection.source_reflection.foreign_key
end
#Primary Key
def through_primary_key
proxy_association.reflection.through_reflection.active_record_primary_key
end
#Through Name
def through_name
proxy_association.reflection.through_reflection.name
end
#Through
def through_collection
proxy_association.owner.send through_name
end
#Captions
def items
through_collection.map(&:read)
end
#Target
def target_collection
#load_target
proxy_association.target
end
end
--
系统
底线是我认为您的系统最好这样运行:
1. Set up a semi-persistent data store to track user / post reads (REDIS)
2. Every time you call a `Post`, you'll be able to call the associated `REDIS` references for it
这将使您能够创建一个首先是模块化的系统,但您也可以创建一个实例方法来确定用户是否已阅读帖子,如下所示:
#app/models/post.rb
Class Post < ActiveRecord::Base
def read?
##Redis lookup for user with post - if "read" attribute is true, return true
end
def liked?
##Redis lookup for user with post - if "liked" attribute is true, return true
end
end
这将允许您运行 @user.posts.first.read?
关于ruby-on-rails - 何时向 user_posts 表添加记录以跟踪 'likes',我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24447999/
我创建了一个用户可以添加测试的字段。这一切运行顺利我只希望当用户点击(添加另一个测试)然后上一个(添加另一个测试)删除并且这个显示在新字段中。 所有运行良好的唯一问题是点击(添加另一个字段)之前添加另
String[] option = {"Adlawan", "Angeles", "Arreza", "Benenoso", "Bermas", "Brebant
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 这个问题似乎不是关于 a specific programming problem, a softwar
我正在努力将 jQuery 滚动功能添加到 nav-tab (Bootstrap 3)。我希望用户能够选择他们想要的选项卡,并在选项卡内容中有一个可以平滑滚动到 anchor 的链接。这是我的代码,可
我正在尝试在用户登录后再添加 2 个 ui 选项卡。首先,我尝试做一个之后。 $('#slideshow').tabs('remove', '4'); $("#slideshow ul li:last
我有一个包含选择元素的表单,我想通过选择添加和删除其中一些元素。这是html代码(这里也有jsfiddle http://jsfiddle.net/txhajy2w/):
正在写这个: view.backgroundColor = UIColor.white.withAlphaComponent(0.9) 等同于: view.backgroundColor = UICo
好的,如果其中有任何信息,我想将这些列添加到一起。所以说我有 账户 1 2 3 . 有 4 个帐户空间,但只有 3 个帐户。我如何创建 java 脚本来添加它。 最佳答案 Live Example H
我想知道是否有一种有效的预制算法来确定一组数字的和/差是否可以等于不同的数字。示例: 5、8、10、2,使用 + 或 - 等于 9。5 - 8 = -3 + 10 = 7 + 2 = 9 如果有一个预
我似乎有一个卡住的 git repo。它卡在所有基本的添加、提交命令上,git push 返回所有内容为最新的。 从其他帖子我已经完成了 git gc 和 git fsck/ 我认为基本的调试步骤是
我的 Oracle SQL 查询如下- Q1- select hca.account_number, hca.attribute3, SUM(rcl.extended_amou
我正在阅读 http://developer.apple.com/iphone/library/documentation/iPhone/Conceptual/iPhoneOSProgrammingG
我正在尝试添加一个“加载更多”按钮并限制下面的结果,这样投资组合页面中就不会同时加载 1000 个内容,如下所示:http://typesetdesign.com/portfolio/ 我对 PHP
我遇到这个问题,我添加了 8 个文本框,它工作正常,但是当我添加更多文本框(如 16 个文本框)时,它不会添加最后一个文本框。有人遇到过这个问题吗?提前致谢。 Live Link: JAVASCRIP
add/remove clone first row default not delete 添加/删除克隆第一行默认不删除&并获取正确的SrNo(例如:添加3行并在看到问题后删除SrNo.2)
我编码this ,但删除按钮不起作用。我在控制台中没有任何错误.. var counter = 0; var dataList = document.getElementById('materi
我有一个类似数组的对象: [1:数组[10]、2:数组[2]、3:数组[2]、4:数组[2]、5:数组[3]、6:数组[1]] 我正在尝试删除前两个元素,执行一些操作,然后将它们再次插入到同一位置。
使用的 Delphi 版本:2007 你好, 我有一个 Tecord 数组 TInfo = Record Name : String; Price : Integer; end; var Info
我使用了基本的 gridster 代码,然后我声明了通过按钮添加和删除小部件的函数它工作正常但是当我将调整大小功能添加到上面的代码中时,它都不起作用(我的意思是调整大小,添加和删除小部件) 我的js代
title 323 323 323 title 323 323 323 title 323 323 323 JS $(document).keydown(function(e){
我是一名优秀的程序员,十分优秀!