问题描述
使用 Rails 6.1.1
我在 rails 上创建了一个枚举的 postgres 实现。但是,在创建记录时,枚举列正在保存枚举的键,而不是我期望的值。
迁移:
execute "CREATE TYPE member_status_type AS ENUM ('New Member','Member Status Not Set')"
add_column :members,:member_status,:member_status_type
MemberEnums.rb
MEMBER_STATUSES = {
new_member: "New Member",member_status_not_set: "Member Status Not Set"}.freeze
会员型号:
enum member_status: MemberEnums::MEMBER_STATUSES
成员创建:
Member.create!({member_status: MemberEnums::MEMBERS_STATUSES[:new_member]})
结果:
=> #<Member id: 12,member_status: "new_member">
我期待的结果应该是
=> #<Member id: 12,member_status: "New Member">
解决方法
会员型号:
enum status: MemberEnums::MEMBER_STATUSES
通过更改枚举的名称,您将获得所需的结果。这可能是因为您为属性和枚举指定了相同的名称