我已经看到了两种不同的保存用户偏好的方法。
方法 1: 将它们序列化并保存在 USERS 表的一列中
方法 2: 创建一个单独的表 PREFERENCES 并建立从 USERS 到 PREFERENCES 的 has_many 关联。
您更喜欢上述两种方法中的哪一种,彼此之间的优缺点是什么?
我已经看到了两种不同的保存用户偏好的方法。
方法 1: 将它们序列化并保存在 USERS 表的一列中
方法 2: 创建一个单独的表 PREFERENCES 并建立从 USERS 到 PREFERENCES 的 has_many 关联。
您更喜欢上述两种方法中的哪一种,彼此之间的优缺点是什么?
支持标准化通常是个好主意。第二种解决方案使您的模型更干净,如果添加了新的首选项,则可以轻松扩展,并使您的表格保持整洁。
我努力解决了同样的问题,所以我想我会分享我在“社区维基”答案中找到的内容。
您的 Rails 应用程序的简单用户偏好是一篇描述如何执行此操作的博客文章。
编辑表单中的序列化哈希?描述了如何在表单中编辑这样的散列。一个有用的技巧是使表单从OpenStruct.new(@user.preferences)
散列自动生成每个散列属性的访问器方法。
DYE/has_serialized - GitHub允许您将序列化哈希中的这些属性视为(用户)模型上的属性。
存储用户设置的最佳实践?有一些提示。以下是一些库,其中两个来自@hopeless 的另一个答案。
您也可以尝试使用元编程: Practical Metaprogramming with Ruby:Storing Preferences
如果您使用的是 PostgreSQL 9.2/3+ 和 Rails 4+,则可以使用第一种方法的改进版本。您可以使用store_accessor
将首选项存储在 PostgreSQL hstore 列中,并支持验证和查询。
class User
store_accessor :preferences, :receive_newsletter
validates :receive_newsletter, presence: true
end
user.receive_newsletter => 'true'
User.where("preferences->'receive_newsletter' = 'true'")
有关更多详细信息(迁移)和处理布尔值的特殊说明,请参见http://mikecoutermarsh.com/using-hstore-with-rails-4/ 。
方法二
您可以添加首选项,而不会弄乱用户表
有一些 Rails 插件可以处理这个用例:
我会接近 2,因为它更干净,更容易更新。您将能够根据需要添加更多复杂的首选项。
因为你要加入,所以会慢一点,但这是值得的
2016 年,我会支持Option 2。
用户设置往往成为每个应用程序的核心部分。如果在每个请求中都检索到它们,那么您现在对每个请求都进行了额外的查询。当您必须为每个设置设置单独的列时,使用单独的表是有意义的。但是由于我们使用的是 jsonb,所以这不是问题。它只是一个列。