Rails将db值增加1

时间:2010-09-30 11:52:40

标签: ruby-on-rails

我的数据库中有一个页面表,其中有一个名为position的字段。

如何在保存之前将该值增加1?

更好的方法是如何删除未使用的位置并为新记录提供正确的位置编号?

2 个答案:

答案 0 :(得分:1)

您需要一个before_save回调:

在你的页面模型中:

before_save :increase_position

def increase_position
  self.position += 1
end

您可以向increase_position方法添加任何类型的逻辑,以删除未使用的位置。

答案 1 :(得分:0)

您需要使用acs_as_list插件或在过滤器之前和之后设置一些。

before_create :set_position
after_destroy :fix_positions

def set_position
   self.position = Page.count + 1
end

def fix_positions
  Page.order('position asc').all.each_with_index do |page, index|
    page.update_attribute(:position, index + 1) unless page.position == index + 1
  end
end
相关问题