2

我有一个具有以下简化架构的 MySQL 数据库表:

create_table "sensors", force: :cascade do |t|
  t.integer  "hex_id",     limit: 8, null: false
end

where在 MySQL中hex_id被声明为 a 。BIGINT我希望用户输入一个十六进制值,然后将其转换为基数 10 并将其保存在hex_id. 为了实现这一点,我想我会创建一个名为的虚拟属性hex来存储十六进制字符串。我的Sensor模型如下所示:

class Sensor < ActiveRecord::Base  
  attr_accessor :hex

  validates :hex, presence: true

  before_create :hex_to_bigint
  before_update :hex_to_bigint

  private
  def hex_to_bigint
    self.hex_id = hex.to_s(10)
  end
end

并且控制器使用标准 rails 生成的代码:

  def new
    @sensor = Sensor.new
  end

  # POST /sensors
  def create
    @sensor = Sensor.new(sensor_params)

    if @sensor.save
      redirect_to @sensor, notice: 'Sensor was successfully created.'
    else
      render :new
    end
  end

我创建了一个带有使用该hex属性的表单的视图。

<%= f.label :hex do %>HEX ID:
    <%= f.text_field :hex, required: true, pattern: '^[a-fA-F\d]+$' %>
<% end %>

当我单击提交时,该params数组具有以下内容:

{"utf8"=>"✓", "authenticity_token"=>"some_long_token", "sensor"=>{"hex"=>"E000124EB63E0001"}, "commit"=>"Create Sensor"}

我的问题是该属性hex始终为空,并且我的验证失败。网络上有很多资源解释了如何使用虚拟属性,但很少有资源解释如何将它们与ActiveRecord. 我花了几个小时寻找一种方法来解决这个相当简单的问题,但没有找到任何可行的方法。任何帮助表示赞赏。我的红宝石版本是 2.0.0p481。谢谢!

4

1 回答 1

2

请添加hex允许的参数。看下面的代码

private

# Never trust parameters from the scary internet, only allow the white list through.
def sensor_params
  params.require(:sensor).permit(:hex_id, :hex)
end

我希望这能帮到您

于 2015-04-15T12:09:22.610 回答