我想为我的网站创建一个赞成票和反对票系统,在这个系统中,唯一用户可以对一个帖子投赞成票/反对票,下次他只允许相反的人从数据库中退出,然后他可以再次赞成或反对否决票。
在这种情况下,我有:
用户表:
id
name
辩论表:
id
post
投票表:
id
user_id
debate_id
和类似的否决表:
id
user_id
debate_id
这是管理和跟踪赞成票和反对票概念的好方法吗?
最佳答案
我认为,您可以使用一个表来跟踪投票,结构可能是这样的
表:投票
id | user_id | debate_id | vote
这里,vote字段可以是tinyInt,默认为null。
并且,在 vote 字段中,您只需根据投票类型保留两个不同的值,例如,如果用户投票,则插入值 1 vote 字段,对于否决票,插入值 0。所以,你的 table 可能看起来像这样
id | user_id | debate_id| vote
1 | 10 | 4 | 1 <-- up
2 | 11 | 4 | 0 <-- down
3 | 12 | 4 | 1 <-- up
在这种情况下,id = 10 和 id = 12 的两个用户对 debate_id = 4 的帖子投了赞成票,而另一个用户user_id = 11 对同一帖子投了反对票。
在这种情况下,您可以通过计算 vote 字段的值来了解帖子获得了多少赞成票或反对票,例如,您可以计算 debate_id = 4 的赞成票> 使用这样的东西
$count = Debate::where('debate_id', '=', 4)->where('vote', '=', 1)->count();
此外,您可以使用一些东西 Query Scope ,这只是一个想法,不可能做出涵盖此范围内所有内容的答案。您应该开始使用一些基本的想法,如果您卡在某个点上,那么您可以用您的代码提出具体问题。
此外,我想提一下,如果您在 votes 表中找到具有特定 debate_id 的用户 ID,那么该用户已对该帖子进行了投票,并且找出投票类型,只需检查 vote 字段 1 或 0。
关于php - Laravel Eloquent 向上投票和向下投票,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19787739/
当我在Rails控制台中按向上或向左箭头时,出现此错误:irb(main):001:0>/Users/me/.rvm/gems/ruby-2.0.0-p247/gems/rb-readline-0.4.2/lib/rbreadline.rb:4269:in`blockin_rl_dispatch_subseq':invalidbytesequenceinUTF-8(ArgumentError)我使用rvm来管理我的ruby安装。我正在使用=>ruby-2.0.0-p247[x86_64]我使用bundle来管理我的gem,并且我有rb-readline(0.4.2)(人们推荐的最少
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我来自C、php和bash背景,很容易学习,因为它们都有相同的C结构,我可以将其与我已经知道的联系起来。然后2年前我学了Python并且学得很好,Python对我来说比Ruby更容易学。然后从去年开始,我一直在尝试学习Ruby,然后是Rails,我承认,直到现在我还是学不会,讽刺的是那些打着简单易学的烙印,但是对于我这样一个老练的程序员来说,我只是无法将它
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭10年前。我使用PHP的时间太长了,对它感到厌倦了。我也想学习一门新语言。我一直在使用Ruby并且喜欢它。我必须在Rails和Sinatra之间做出选择,那么您会推荐哪一个?Sinatra真的不能用来构建复杂的应用程序,它只能用于简单的应用程序吗?
我正在查看有关divmod的文档.下面显示了方法div、divmod、modulo和remainder之间差异的部分表格:为什么13.div(-4)四舍五入为-4而不是-3?Ruby中是否有向下舍入负数的规则或约定?如果是这样,为什么下面的代码没有向下舍入?-3.25.round()#3 最佳答案 13.div(-4)==-4和13.modulo(-4)==-3这样(-4*-4)+-3==13你得到了一致的关系(b*(a/b))+a.modulo(b)==aWhyis13.div(-4)roundedto-4andnotto-3?这
我很确定Ruby有这些(等同于__call、__get和__set),否则find_by将如何在Rails中工作?也许有人可以举一个简单的例子来说明如何定义与find_by相同的方法?谢谢 最佳答案 简而言之你可以映射__调用带有参数的method_missing调用__设置为方法名称以'='结尾的method_missing调用__获取不带任何参数的method_missing调用__调用PHPclassMethodTest{publicfunction__call($name,$arguments){echo"Callingob
Lisp是否适合Web编程/应用程序(交互式),就像ruby和php一样?需要考虑的事情是:易于使用可部署性难度(尤其是对于编程初学者而言)(编辑)在阅读PaulGraham'sessay之后,我特别提到了CommonLisp.将是我的第一门编程语言。在这方面。这样做合适吗?我听说Clojure的宏功能不如CommonLisp的强大,这就是我尝试学习Clojure的原因。它教授编程并且非常强大。 最佳答案 Lisp是一个语系,而不是单一的语言。为了稍微回答您的问题,是的,存在用于各种Lisp方言的Web框架,例如用于Common
文章目录网络层数据平面和控制平面两者的概述数据平面控制平面控制平面:传统方法控制平面:SDN方法网络服务模型路由器工作原理通用路由器体系结构输入端口的功能基于目标的转发交换结构内存交换方式总线交换方式纵横式交换方式输出端口的功能何时何处出现缓存队列输入排队输出排队分组调度先进先出优先权排队循环和加权公平排队网络协议:PIv4、寻址、IPv6以及其它IPv4数据报格式IPv4数据报分片IPv4编址IP和子网掩码CIDR分类网络特殊地址分配地址获取一块地址(用于组织的子网内)获取主机地址:动态主机配置协议网络地址转换——NAT一些术语通用转发和SDN匹配动作参考资料网络层从表面上看网络层的作用:将
项目背景和意义 目的:本课题主要目标是设计并能够实现一个基于微信校园跑腿小程序系统,前台用户使用小程序发布跑腿任何和接跑腿任务,后台管理使用基于PHP+MySql的B/S架构;通过后台管理跑腿的用户、查看跑腿信息和对应订单。意义:手机网络时代,大学生通过手机网购日常用品、外卖外卖、代取快递等已不再是稀奇的事情。此外,不少高校还流行着校园有偿工作,校园跑腿就成了大学生创业服务项目。 因为你在校园里,所以不会有进入的限制。并不是所有的外卖平台都可以随意进入校园,比如小黄和小蓝的双打外卖平台。许多大学禁止送餐进入学校,更不用说送餐进入宿舍了。这一措施使得校园服务市场的竞争相对不
前言 前端时间PHP项目部署升级需要,需要把Laravel开发的项目部署K8s上,下面以laravel项目为例,讲解采用yaml文件方式部署项目。一、部署步骤1.创建Dockerfile文件Dockerfile是一个用来构建镜像的文本文件,在容器运行时,需要把项目文件和项目运行所必须的组件安装其中。#基础镜像FROMphp:7.4-fpm#时区ARGTZ=Asia/Shanghai#更换容器时区RUNcp"/usr/share/zoneinfo/$TZ"/etc/localtime&&echo"$TZ">/etc/timezone#替换成阿里apt-get源RUNsed-i"s@http
关闭。这个问题不符合StackOverflowguidelines.它目前不接受答案。要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于StackOverflow来说是偏离主题的,因为它们往往会吸引自以为是的答案和垃圾邮件。相反,describetheproblem以及迄今为止为解决该问题所做的工作。关闭9年前。Improvethisquestion我对学习Rails很感兴趣已经有一段时间了,我觉得现在正是浸入其中并实际动手实践的好时机。在过去的一周里,我阅读了所有我能找到的关于Ruby和RubyonRails的免费电子书。我刚刚读完RubyEssentials。我也一直在玩htt