Rails/Postgres 枚举实现使用枚举键创建记录,而不是它的值

问题描述

使用 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

通过更改枚举的名称,您将获得所需的结果。这可能是因为您为属性和枚举指定了相同的名称