首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >如果用户不输入任何rails 4,.where返回零异常

如果用户不输入任何rails 4,.where返回零异常
EN

Stack Overflow用户
提问于 2016-10-06 12:18:59
回答 2查看 51关注 0票数 0

我想根据用户从表中查询一些数据以供提交。

它可以正常工作,但是如果我在字段中不发布任何内容并发布我的表单,它会返回零异常。

有什么方法可以处理零异常,还是需要更改查询?

代码语言:javascript
运行
复制
question_options = question.question_options.where(id: self.option_id).first
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2016-10-06 12:20:11

最简单的解决方案是使用try。例如:

代码语言:javascript
运行
复制
question_options = question.question_options.where(id: self.option_id).try(:first)

try的文档是这里

票数 0
EN

Stack Overflow用户

发布于 2016-10-06 12:38:33

对于您的问题,存在多个解决方案。查询返回nil,这是可以的,因为没有找到任何内容。最简单的解决方案是if语句。if question_options.nil?做了些别的事。或者您可以使用统一对象(或NullObject)来处理它,question_option = question.question_options.where(id: self.option_id).first || QuestionOption.new

这些也是其他的可能性。这取决于你的要求,你选择什么方式。

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

https://stackoverflow.com/questions/39895804

复制
相关文章

相似问题

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