One more thing. I debugged my app and when I inspect my @order object, the product field is being correctly set. I debugged a little deeper and it looks like at some point, Rails is trying to decide to set a particular option to selected by evaluating something like the following (assuming product id 7 was selected):
"7" == 7 It looks like, for the purpose of setting my model's attributes, the product id is being turned into an integer, but for selecting a value in collection_select, it is keeping it a string. Very confusing. -Eric On Jan 2, 2:56 am, emarthinsen <[email protected]> wrote: > Hello- > > I have a form that I'm using form_for on to bind the form to my order > object. Within the form, I want to select a product (each order has > one product, which makes this easy). In my order and product models, > an order belongs_to a product. I didn't specify that a product > has_many orders (although I did test that the problem still exists > even if I do specify that). Here's the code I'm using to generate the > select list: > > @packages = Package.find(:all, :order => 'name') #this is in my > controller > > <%= f.collection_select :product, @products, :id, :name, { :prompt => > '--select one--'} %> > > The call to collection_select creates the list of options just fine, > but if my order has a value set for product, it doesn't get set as the > selected value. > > I've tried a slew of other variations on the call to collection_select > (e.g., using :product_id instead of :product) and all seem to fail. > > Does anyone know what I might be doing wrong? > > Regards, > Eric --~--~---------~--~----~------------~-------~--~----~ 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 [email protected] To unsubscribe from this group, send email to [email protected] For more options, visit this group at http://groups.google.com/group/rubyonrails-talk?hl=en -~----------~----~----~----~------~----~------~--~---

