2014-06-19 52 views
2

在我的Rails应用程序中,update_attribute似乎无法正常工作。我试图更新一个名为billed的布尔字段。同样的命令对另外两个表很有用。Rails update_attributes不起作用

输出的rails console

>> Expense.find(28).update_attributes(:billed => true) 
=> false 
>> Expense.find(28).billed 
=> false 

expenses_controller.rb

# PUT /expenses/1 
# PUT /expenses/1.json 
def update 
    @expense = Expense.find(params[:id]) 

    respond_to do |format| 
    if @expense.update_attributes(params[:expense]) 
     format.html { redirect_to @expense, notice: 'Expense was successfully updated.' } 
     format.json { render json: @expense } 
    else 
     format.html { render action: "edit" } 
     format.json { render json: @expense.errors, status: :unprocessable_entity } 
    end 
    end 
end 

费用有这些验证:

validates_presence_of :employee_id  # Declare a required field 
    validates_presence_of :unitcost   # Declare a required field 
    validates_presence_of :quantity   # Declare a required field 
    validates_presence_of :exp_date   # Declare a required field 
    validates_presence_of :category_id  # Declare a required field 
    validates_presence_of :description  # Declare a required field 
    validates_presence_of :markup   # Declare a required field 
    validates :markup, :format => { :with => /^\d{3}$/}, :numericality => {:greater_than => 0} 
    validates :unitcost, :format => { :with => /\A\d+(?:\.\d{0,2})?\z/}, :numericality => {:greater_than => 0} 
    validates_numericality_of :quantity, :only_integer => true, :message => "Can only be whole number." 

感谢您的帮助!

+1

你对费用验证其 ? –

+0

是的 - 我会补充问题。 – Reddirt

+0

使用'update_attribute'而不是'update_attributes'来更新单列。 – Pavan

回答

4

使用update_attribute,而不是update_attributes更新单列。

API

update_attribute

更新单个属性并保存记录,而无需通过 会正常验证程序。这对于现有记录上的布尔值 标志特别有用。在基地 常规update_attribute方法替换为当验证模块,混合,它是默认

Expense.find(28).update_attribute(:billed => true)