Hi Ma We, On Tue, Jun 8, 2010 at 5:23 AM, Ma We <li...@ruby-forum.com> wrote:
> The parameters of my update are looking like this: > Parameters: {"commit"=>"Update", "action"=>"update", "_method"=>"put", > "authenticity_token"=>"***", "product"=>{"image_url"=>"w.jpg", > "expirience_points"=>"0", "price"=>"1", "title"=>"w", > "description"=>"w", "continent_id"=>"7"}, "id"=>"11", > "controller"=>"products"} > > This is the code of may update methode: > def update > @product = Product.find(params[:id]) > @product.continent = Continent.find(:first, :conditions => [ "id = > ?",:continend_id ]) You haven't posted what you're getting as a result, but one problem is that you don't have a variable named continend_id in your code. You have a params element named continent_id. Change the Continent.find clause to use :params[:continent_id]. A couple of other tips. I always use .to_i on finds where I'm using a param since they're strings and find takes an integer. It helps to remind me that params are strings. Your Continent.find could be shortened to Continent.find(params[:continent_id].to_i) HTH, Bill -- You received this message because you are subscribed to the Google Groups "Ruby on Rails: Talk" group. To post to this group, send email to rubyonrails-t...@googlegroups.com. To unsubscribe from this group, send email to rubyonrails-talk+unsubscr...@googlegroups.com. For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en.