Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/ruby-on-rails/58.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ruby on rails 如何在RubyonRails4应用程序中基于答案更新数据库列_Ruby On Rails_Ruby - Fatal编程技术网

Ruby on rails 如何在RubyonRails4应用程序中基于答案更新数据库列

Ruby on rails 如何在RubyonRails4应用程序中基于答案更新数据库列,ruby-on-rails,ruby,Ruby On Rails,Ruby,我有一个测验应用程序,我一直在努力学习更多关于RubyonRails的知识。现在它会告诉你答案是否正确,然后进入下一个问题,在最后给出一个百分比。我还想为每个正确答案加分。我在数据库的users表中有一个points列,但似乎无法将如何为每个正确答案将该数字增加1的点连接起来 控制器中应答方法的def如下所示。我是新手,但我的直觉告诉我,我需要把代码放在if语句下,我说的对吗?有谁能帮助我根据正确的回答将当前登录用户的积分列中的数字增加1吗 谢谢你的帮助 def answer @c

我有一个测验应用程序,我一直在努力学习更多关于RubyonRails的知识。现在它会告诉你答案是否正确,然后进入下一个问题,在最后给出一个百分比。我还想为每个正确答案加分。我在数据库的users表中有一个points列,但似乎无法将如何为每个正确答案将该数字增加1的点连接起来

控制器中应答方法的def如下所示。我是新手,但我的直觉告诉我,我需要把代码放在if语句下,我说的对吗?有谁能帮助我根据正确的回答将当前登录用户的积分列中的数字增加1吗

谢谢你的帮助

   def answer
    @current = session[:current]
    @total   = session[:total]
    choiceid = params[:choice]

   @question = session[:question]
   @choices  = session[:choices]

   @choice = choiceid ? Choice.find(choiceid) : nil
   if @choice and @choice.correct
     @correct = true
     session[:correct] += 1
   else
     @correct = false
    end

   session[:current] += 1
end

如果我理解正确,你需要这样的短信

if @choice and @choice.correct
  @correct = true
  session[:correct] += 1
  current_user.increment(:points)
else
  @correct = false
end
方法将1添加到当前值(或使用0初始化值并添加1)


但我建议你另一种模式。您当前系统的问题是:它没有“历史”。您将无法说出用户有什么答案、什么答案正确、用户何时回答等等

我建议创建几个表:

#User: 
has_many :answers

#Quiz:
has_many :questions

#Question:
belongs_to :quiz
has_many :answers

#Answer:
belongs_to :quiz
belongs_to :question
belongs_to :user
在模型答案中,您可以保存真实答案、分数、时间戳等以计算测验的用户分数:
Answer.where(user\u id:user.id)。where(quick\u id:quick.id)。sum(:points)


PS建议的模式只是一个想法,可以根据您的需求进行修改

如果我理解正确,你需要这样的短信

if @choice and @choice.correct
  @correct = true
  session[:correct] += 1
  current_user.increment(:points)
else
  @correct = false
end
方法将1添加到当前值(或使用0初始化值并添加1)


但我建议你另一种模式。您当前系统的问题是:它没有“历史”。您将无法说出用户有什么答案、什么答案正确、用户何时回答等等

我建议创建几个表:

#User: 
has_many :answers

#Quiz:
has_many :questions

#Question:
belongs_to :quiz
has_many :answers

#Answer:
belongs_to :quiz
belongs_to :question
belongs_to :user
在模型答案中,您可以保存真实答案、分数、时间戳等以计算测验的用户分数:
Answer.where(user\u id:user.id)。where(quick\u id:quick.id)。sum(:points)

PS建议的模式只是一个想法,可以根据您的需求进行修改

试试这个:

当前用户增量!(:分)

试试这个:

当前用户增量!(:分)


非常感谢你的详细回答。我把所有的东西都准备好了,只是我遗漏了它的措辞。这将是一个伟大的答案,有人希望建立这样的东西,因为这是如何建立模型关系。非常感谢详细的答案。我把所有的东西都准备好了,只是我遗漏了它的措辞。这将是一个伟大的答案,有人希望建立这样的东西,因为这是如何建立模型关系。哇,我一定尝试过的每一个变种,但这一个,谢谢你的帮助。哇,我一定尝试过的每一个变种,但这一个,谢谢你的帮助。