我的数据库中有一个页面表,其中有一个名为position的字段。
如何在保存之前将该值增加1?
更好的方法是如何删除未使用的位置并为新记录提供正确的位置编号?
答案 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