我正在 Rails 中开发电子学习,我想将一组数组保存到数据库中,目的是跟踪用户在电子学习各个部分的进度。
我遇到过这个问题并回答:
在数据库中存储数组:JSON 与序列化数组 https://stackoverflow.com/questions/21312278/storing-arrays-in-database-json-vs-serialized-array/21315340?noredirect=1#comment40564161_21315340
...听起来它可能很有用,但我不知道如何将它集成到我正在开发的 Rails 项目中。
鉴于我几乎是一个 Rails 菜鸟,有人可以用简单的英语(或者简单的代码)向我解释一下我会如何:
a) 将一个数组保存到数据库中,当用户最初注册时,该数组保存一系列“假”布尔值。
b) 在整个电子学习过程中从各个页面检索并更新该数组。
我会列出我已经尝试过的内容,但这只是在黑暗中进行的疯狂尝试,我真的不知道从哪里开始。 Comment 类应该保存在controllers 文件夹中吗?或者,在我的示例中,它实际上是 User 类(类似地,它扩展了 ActiveRecord)?
再次,非常感谢任何帮助(最好解释代码所属的位置)。
UPDATE
我被要求更具体,所以我会尝试:
我在数据库中有一个用户表,(可以预见)它有几个字段,包括电子邮件、用户名等。我想向用户表中添加 5 个字段,每个字段存储一个数组来跟踪用户在每个字段中的进度5个部分。我设想,当用户打开一段内容时,数组将被更新,并且适当的索引将被更新为“true”以标记该部分的该部分已完成。
我希望这有帮助...
重新更新
当用户第一次注册时,我希望使用一系列“假”布尔值设置数组。我将从哪个文件设置数组?这是在用户中完成的吗?目前我正在尝试这个,但我不认为这些值正在被设置 - 尽管它没有抛出错误。
class User < ActiveRecord::Base
# Include default devise modules. Others available are:
# :confirmable, :lockable, :timeoutable and :omniauthable
serialize :leadership_styles_progress
serialize :skills_progress
serialize :safeguarding_progress
serialize :tools_progress
before_create :set_progress_vars
devise :database_authenticatable, :registerable,
:recoverable, :rememberable, :trackable, :validatable
validates :age, presence: { :message => ": Please choose your age" }
validates :section, presence: { :message => ": Please choose the section you belong to"}
has_many :posts
private
def set_progress_vars
self.leadership_styles_progress = [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false]
self.skills_progress = [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false]
self.safeguarding_progress = [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false]
self.tools_progress = [false, false, false, false, false, false, false, false, false, false, false, false, false, false, false, false]
end
end
我还通过“rake 路线”检查了哪些路线映射到了哪里; users/sign_up 映射到 devise/registrations/new。那么下面建议的序列化代码会去那里吗?