开发者

How to override a column in Rails model?

开发者 https://www.devze.com 2023-03-04 14:30 出处:网络
I have a model for one of my database tables. I want to override the column name for that particular table. How would I achieve it.

I have a model for one of my database tables. I want to override the column name for that particular table. How would I achieve it.

For example, let my table be called DUMMY and it has one col开发者_Python百科umn called col_a

col_a
20
34
42
23
12

I would be doing a @dummy.col_a. Now this method should return me 0 for numbers ending with 0 and for everything else, it should return the original value. I could do that by defining a new method, but I want to override the column name itself. Please help.


You can override the col_a method. Use the read_attribute method to read the value in database. Something like this:

def col_a
  if self.read_attribute(:col_a).to_s.end_with?('0')
    0
  else
    self.read_attribute(:col_a)
  end
end


You can simply define a method of the same name as the column. To get the actual column value, use self[column_name]. So something like this should work:

class Dummy < ActiveModel::Base
  def col_a
    self[:col_a] % 10 == 0 ? 0 : self[:col_a]
  end
end

(This assumes col_a is an integer.)


I'm a little late to the party here, but a really elegant way to do it is to simply use super

class Dummy < ApplicationRecord
  def col_a
    super % 10 === 0 ? 0 : super
  end
end


You can achieve that by overwriting default accessors as described in the documentation. All column values are automatically available through basic accessors on the Active Record object, but sometimes you want to specialize this behavior. This can be done by overwriting the default accessors (using the same name as the attribute) and calling read_attribute(attr_name) and write_attribute(attr_name, value) to actually change things.

Scroll to the Overwriting default accessors section for more info.

0

精彩评论

暂无评论...
验证码 换一张
取 消