- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的 votes
表如下所示:
id: integer
vote: boolean
voteable_id: integer
voteable_type: string
voter_id: integer
voter_type: string
vote
列确定该行表示“赞成票”(vote = true
) 还是“反对票”(vote = false
).
voteable_type
是被投票对象的类,voteable_id
是被投票对象的id,voter_type
是类选民的身份,voter_id
是选民的 id。
我需要的是一个查询,以按“投票得分”降序获取前 n 个帖子
,其中“投票得分”定义为(帖子的赞成票数)-(帖子的反对票数)。
如果您的解决方案不需要我求助于 find_by_sql()
(我在 Rails 中工作),则加分
如果您的解决方案在 SQLite 和 PostgreSQL 中的工作方式相同(尽管它在 PostgreSQL 中工作更重要),则会获得更多奖励。
最佳答案
通常,您可以使用 case
来完成此操作带有 sum
的语句:
select
voteable_id,
sum(case
when vote then 1
else -1
end) as vote_score
from
votes
group by
voteable_id
请注意,这是 ANSI SQL,因此适用于 SQLite、MySQL、Postgres、Oracle、SQL Server、DB2 等。
要获得前 N 个帖子,您只需将其附加到上述查询即可:
order by
vote_score desc
limit 10
limit
由 Postgres 和 SQLite(在 MySQL 中略有不同)使用,而不是在 Oracle 或 SQL Server 中用作 FYI。
因此,要获取与此相关的帖子信息:
select
p.title,
p.author,
p.createdate,
sum(case
when v.vote then 1
else -1
end) as vote_score
from
posts p
inner join votes v on
p.post_id = v.voteable_id
group by
p.title,
p.author,
p.createdate
order by
vote_score desc
limit 10
关于SQL查询得到 "vote score",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1416607/
我的 .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 表和一个单独的表“投票”。当用户单击“喜欢”按钮时,它会将值为“
我是一名优秀的程序员,十分优秀!