Rails -- 如何设置可以属于 3 个不同模型中的任何一个的模型

发布于 2024-09-14 14:09:26 字数 329 浏览 10 评论 0原文

我正在尝试制作一个应用程序,它可以进行类似于您在学校中经历的测试。

我有一个模型问题,它可以属于考试、测验或作业。

我应该为“:exam_id, :integer, :null => false; :quiz_id, :integer, :null => false; :assignment_id, :integer, :null => false;”创建字段吗?

该问题将属于其中一个或几个或全部(因此我可以在差异模型中重复使用相同的问题)。

我应该删除 :null=>false 以便它可以属于它们中的任何一个......或者设置它的最佳方法是什么?

I'm trying to make an app that does testing similiar to what you would experience in school.

I have a model Question, which can belong to either an Exam, Quiz, or Assignment.

Should I create fields for ":exam_id, :integer, :null => false; :quiz_id, :integer, :null => false; :assignment_id, :integer, :null => false;"?

The question will belong to either one or a few or all of them ( so i can reuse the same question in diff models).

Should I remove the :null=>false so it could belong to either of them....or what the best way to set that up?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

飘然心甜 2024-09-21 14:09:26

听起来您想要在这里做的是使用多态关系。您需要为考试/测验/作业指定一个通用名称,每个问题都属于其中一个。假设您将它们称为“评估”,您将像这样设置您的模型:

class Question << ActiveRecord::Base
  belongs_to :assessment, :polymorphic => true
end

class Exam << ActiveRecord::Base
  has_many :questions, :as => :assessment
end

class Quiz << ActiveRecord::Base
  has_many :questions, :as => :assessment
end

class Assignment << ActiveRecord::Base
  has_many :questions, :as => :assessment
end

然后您需要将两个字段添加到您的问题模型中:

assessment_id
assessment_type

有了这种关系,您可以像这样使用它:

@exam = Exam.create({:field1 => :val1})    
@exam.questions.create({:field1 => :question1})
@exam.questions.create({:field1 => :question2})

并且它将确切地知道哪些问题属于哪个模型关于问题模型中的其他字段。

It sounds like what you want to do here is use a polymorphic relationship. You will need a generic name for exam/quiz/assignment and each question will belong to one of these. Say you call them Assessments, you would set up your models like this:

class Question << ActiveRecord::Base
  belongs_to :assessment, :polymorphic => true
end

class Exam << ActiveRecord::Base
  has_many :questions, :as => :assessment
end

class Quiz << ActiveRecord::Base
  has_many :questions, :as => :assessment
end

class Assignment << ActiveRecord::Base
  has_many :questions, :as => :assessment
end

Then you will need to add two fields to your Question model:

assessment_id
assessment_type

With this relationship, you can use it like:

@exam = Exam.create({:field1 => :val1})    
@exam.questions.create({:field1 => :question1})
@exam.questions.create({:field1 => :question2})

and it will know exactly which questions belong to which model based on the additional fields in your question model.

青芜 2024-09-21 14:09:26

我可能会为每个关系创建一个查找表,这样您就会有一个 exam_questionsquiz_questionshomework_questions 表。

其中每个都包含所有者的 ID(例如 exam_id)和问题(question_id)。

这样,如果一个问题仅属于三个关系中的一个或两个,您只需为这些关系创建行。如果您要引入新的所有者类型(例如 studyguide 等),这也使得添加新关系变得非常容易。

您将保留 :null =>; false 在此方法中,因为关系要么存在,要么不存在。

I would probably create a look up table for each relationship, so you would have an exam_questions, quiz_questions, and homework_questions table.

Each of these would contain the id of the owner (exam_id for example), and the question (question_id).

This way if a question belonged to only or two of the three, you could just create rows for those relationships. This also makes it very easy to add new relationships if you were to introduce a new owner type, like studyguide or something.

You would leave the :null => false in with this method, since a relationship will either exist or it won't.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文