首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >rails实现Post模型的"repost“操作

rails实现Post模型的"repost“操作
EN

Stack Overflow用户
提问于 2015-01-29 09:54:51
回答 1查看 582关注 0票数 1

我有一个UserPost模型与关联one-to-many。我尝试实现一个repost操作,通过一个表has_and_belongs_to_many添加一个链接reposts

但我面临以下挑战:

( 1)以下列方式将所装载的饲料邮寄:

代码语言:javascript
复制
followed_users="SELECT  followed_id FROM relationships WHERE follower_id = :user ";
replics_posts="SELECT micropost_id FROM replics_users WHERE user_id = (:user)"
reposts="SELECT post_id FROM reposts WHERE user_id = (:user)"

where("user_id IN(#{followed_users}) OR user_id= (:user) OR id IN(#{replics_posts}) OR id in (#{reposts})", user: user);

并按修改的日期排序。重新发布类似的排序,其中有一种情况是重新张贴在中间的饲料。

2)没有额外的努力,追随者没有看到转发用户。

这些问题可以通过辅助阵列解决,需要快速,但它看起来荒谬和非最优的解决方案。

我怎样才能摆脱这种局面?

我认为该解决方案可以通过参考字段"Content“在同一字段上的Post模型中找到,这是另一个对象。然后,repost操作将不需要单独的表,只包含一个新的Post对象,该对象具有指向原始post内容的指针。但我不知道如何在中做到这一点。

谢谢你的帮助!

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-01-29 16:42:23

我更正如下:

1)在Post模型中添加了一个新的字段repost_id和引用:

代码语言:javascript
复制
has_many: reposts, class_name: "Post", foreign_key: "repost_id", dependent:: destroy;

(与User模型的关系未更改)

2)加入Post的控制器方法repost

代码语言:javascript
复制
  def repost
    orig_post=Micropost.find(params[:id]);
    if(orig_post)
      Micropost.create(user_id:current_user.id, 
        content: orig_post.content, 
        repost_id:orig_post.id);
      respond_to do |format|
        format.js
      end 
    end 
  end

(别忘了认识到既满足了岗位的路径,又实现了岗位的验证创造)

结果是一个正确的行为行为模型,重新发布了依赖项并在提要中正确显示。但遗憾的是,这种方法需要在"Content“字段中的表Posts中存储重复的数据。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28211614

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档