- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我是 Rails 的新手,所以不要着急。我创建了一个博客,还为用户创建了表示他们“喜欢”特定帖子的功能。我实现它的方法是使用 post 表和一个单独的表“投票”。当用户单击“喜欢”按钮时,它会将值为“1”和特定帖子 ID 的记录发送到“投票”表。
我想在侧边栏中显示“最喜欢”的帖子。我该如何调用这样的东西。我想显示 post_title 和“投票”的数量,也就是说,我想以某种方式查询“投票”表以获得记录最多的 post_id 并按降序显示它们。
我希望这是一个简单的问题。
最佳答案
有几种方法可以做到这一点,但可能最通用和 Rails-ish 是创建一个模块,其中包含一个方法来进行排名,然后让任何可以“喜欢”的类或关联扩展该模块.
# lib/likable.rb
#
module Likable
def most_liked (limit = 10)
# This may be possible without a find_by_sql... see the API docs.
find_by_sql("SELECT Posts.*, SUM(votes.count) AS num_votes FROM Posts, Votes WHERE Posts.id = post_id GROUP BY post_id ORDER BY num_votes DESC LIMIT #{limit}")
end
end
# app/models/post.rb
#
require 'likable'
class Post < ActiveRecord::Base
extend Likable
# ...whatever else you've got in here
end
# app/models/user.rb (or any other model with things that can be "liked")
#
require 'likable'
class User < ActiveRecord::Base
has_many :posts, :extend => Likable
# ...the rest of the User class
end
这让您可以做...
Post.most_liked # => an array of the 10 most liked posts
@some_user.posts.most_liked(5) # => that user's 5 most liked posts
如果您稍后需要,您可以向模块添加方法以查看,例如,特定帖子有多少票。您还可以在 Vote
中将 post_id
更改为 target_id
并使其成为多态关联,然后您可以使用您的 Likable 模块投票任何东西,而不仅仅是帖子(如果你这样做的话,你需要概括调用以在 most_liked 中查找)。
关于ruby-on-rails - 在单独的表中按 "vote"记录数显示帖子,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1771630/
我的 .htaccess 文件需要帮助。到目前为止,似乎没有任何效果。我制作了一个名为 vote.php 的 PHP 文件,它使用 GET 变量将用户重定向到适当的投票网站。现在,我希望用户能够键入
我喜欢做一些简单的事情,但我不知道从哪里开始。 所以我有 4 张 table : Table question (id_question) Table trad (id_trad, #id_quest
每个用户可以为每个项目投票一次(只有注册用户可以投票)。所以我有一个用户投票表,其中包括用户 ID、投票项目 ID 和投票值(从 1 到 10)。 我需要显示每个项目的总票数和评分,所以我想知道什么是
没有通用 View ,一切正常 NoReverseMatch at /app1/2/ Reverse for 'vote' with arguments '('',)' not found. 1 pa
我正在构建一个高度依赖匿名用户对某种项目进行投票的小型应用程序。它太小了,需要注册会很乏味,而且没有道理。 无论如何,我对此做了一些研究,包括在 stackoverflow ( https://sta
我希望使用我的应用程序向 Facebook 提交几张图片,并邀请我的 friend 在特定的时间间隔内对其进行投票。我的问题是—— graphAPI 是否支持这一点。 我可以将它与我的后端系统集成,以
关闭。这个问题是off-topic .它目前不接受答案。 想改善这个问题吗? Update the question所以它是 on-topic对于堆栈溢出。 12 年前关闭。 Improve this
我的 votes 表如下所示: id: integer vote: boolean voteable_id: integer voteable_type: string voter_id: integ
我被要求设计一个网络解决方案,以允许在公共(public)集会中投票。 该解决方案应在服务器上使用 node.js 和 javascript 编写,可能在客户端上使用 angular.js (因为ja
我有一个模型帖子和一个模型投票。 Vote(来自 django-voting)本质上只是一个指向 Post 和 -1、0 或 1 的指针。 还有巡回赛,它是开始日期和结束日期。在锦标赛开始和结束之间发
我有三个表Feed、Vote 和Event。 Feed +id +content +voteCount --> hold the number of votes on this feed Vote
您好,我正在构建一个允许对视频进行投票的视频投票网站。我希望用户能够在不中断视频播放的情况下投票。 这是我正在使用的片段。 if ($_POST['vote']) { $sql = mysql
我正在编写一个内联网应用程序,其功能之一大致类似于内容投票 - 与 SO、Amazon 和许多其他网站所做的没什么不同。 假设每个可投票的内容都有一个唯一的 ID,并且每个用户(他们经过身份验证)都有
我需要扩展标准 XMPP 协议(protocol)的功能,以便能够执行投票 session (在多用户聊天中)。请指导我 - 我可以使用一些现有的 XEP(如数据表单)还是我需要实现一些自定义 XEP
我们公司使用 HP 质量中心来管理/跟踪缺陷和其他类型的问题。 我想拥有一个单独的系统或与 QC 的某种集成,以允许我团队中的开发人员对问题进行投票。 这可以在 QC 上做吗?它是其他问题跟踪器的固有
我正在尝试创建一个简单的 Google 电子表格函数,将排名转换为积分系统,然后添加积分。有权访问电子表格的人 (A、B、C、D) 将根据第一选择 (1)、第二选择 (2) 和第三选择 (3) 对他们
一般来说,如何阻止用户看到他已经投票过的个人资料,这样他就不会对其投票两次? 我有一个用户表(称为“用户”),每个用户都有一个唯一的用户 ID(列为“userID”),我还有另一个表(称为“投票”),
我已经盯着这个看了 20 分钟,无法理解它。我以前做过,我只是不记得在哪个项目中(所以我可以引用代码)。 我有这样一张表: votes [table] id - serial , primary
我有一个投票表,其中包含一个 post_id 列、一个 user_id 列和一个 vote 列。当有人为某个帖子投票时,会添加一行记录他们投票的帖子的 ID、他们的 user_id,并且 vote 列
我是 Rails 的新手,所以不要着急。我创建了一个博客,还为用户创建了表示他们“喜欢”特定帖子的功能。我实现它的方法是使用 post 表和一个单独的表“投票”。当用户单击“喜欢”按钮时,它会将值为“
我是一名优秀的程序员,十分优秀!