gpt4 book ai didi

mysql - PORO 可以访问数据库吗?

转载 作者:行者123 更新时间:2023-11-29 07:36:57 25 4
gpt4 key购买 nike

作为我的第一个 Rails 应用程序,我正在构建一个作业管理应用程序,其中包含以下表格:

  • 用户(来自 Devise 身份验证)
  • 学校
  • 类(class)
  • 作业

与我发现的大多数类(class)/评分应用程序示例不同,这个应用程序从不关心特定类(class)的所有学生的所有成绩,而只是学生和类(class)之间的一对多关系。所以这些例子并没有真正帮助我。

为了计算用户在任何给定类(class)中的当前成绩(需要访问类(class)模型和作业模型中的数据),我遵循 Stack Overflow 上的建议并在 app/models 目录中创建 PORO称为成绩计算器。

但这是我第一次将 PORO 构建到 Rails 应用程序中,而且我在网上找到的大多数文档都是针对更复杂的用户的。我假设它不需要 Controller (如果我错了,请纠正我),并且我发现构建它就像这样简单:

应用程序/模型/gradecalculator.rb

Class GradeCalculator

def calculate_current_course_grade(course_id)
@graded_course_assignments = Assignment.where(user_id: current_user.id, course_id: course_id, graded: true)
#grab weights for each type of assignment in @graded_course_assignments from courses table
#do some calculations
#return the array
end

def calculate_user_GPA(current_user.id)
#more of the same
end

end

我的问题是:

  1. PORO 可以访问数据库(从类(class)和作业表中获取数据)。或者在调用它时我是否需要将其他类(例如作业)中的所有相关数据作为参数传递给它?

    1a。如果一个简单的类可以访问数据库,那么语法与模型中的语法是否不同?上面的代码可以访问Assignment.where吗?

    1b。我该怎么称呼这个 PORO?例如,我如何从 View /分配/index.html.erb 中调用它?

  2. 它可以访问 Devise 的 current_user 帮助程序吗?

  3. 顺便说一句,我刚刚意识到我可以将分配权重存储在分配表中。我按时间顺序思考(用户在输入新类(class)时输入家庭作业、测验等的数量,这决定了每种类型作业的权重),但我可以通过编程方式让每个新作业填充自己的权重字段引用其父类(class)中类似作业的数量。从逻辑上讲,这意味着我可以在作业模型中正确计算成绩。但是,如果类(class)中添加了额外学分或其他更改,则所有作业可能都必须重新计算其权重。哪种方式更正确呢?

写这些问题让我怀疑我只是将我认为的相关数据传递给 PORO,让它对这些数据进行计算并返回成绩。但无论如何我都会发帖,以防万一我错了。

最佳答案

像这样将业务逻辑分解为 PORO 的原因通常是为了使您的代码更易于推理并且更容易(且更快)测试。为此,您不希望 GradeCalculator 了解或关心作业的工作原理。您应该只向 GradeCalculator 传递它需要的所有数据(或关系,它像 Enumerable 一样嘎嘎叫)。让 GradeCalculator 调用 Assignment.where 意味着您的测试将依赖于 ActiveRecord 和数据库,这意味着它们会很慢。如果 GradeCalculator 只是需要一个数组,那么在测试中,您只需模拟一个对象数组,这些对象响应 GradeCalculator 需要了解的任何属性方法,并且您将能够在根本不加载 Rails 的情况下运行它们。 (通常有一个单独的 spec_helper.rbrails_helper.rb,这样不需要 Rails 的规范就可以在不加载 Rails 的情况下运行,这使得它们如此 快得多。)

对于你的第二个问题,我的建议是类似的:尽可能将 PORO 与 Rails 和 Devise 分离。

关于mysql - PORO 可以访问数据库吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30431766/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com