我有一个模型Dish和PriceDeal如下
class Dish < ActiveRecord::Base
has_one :price_deal
end
class Dish < ActiveRecord::Base
belongs_to :dish
end
在rails控制台中,我想像这样检索discountPercent值。
1.9.2p290 :130 > pd=PriceDeal.find(17)
=> #<PriceDeal id: 17, name: "deal1", description: "my deal1", discountPercent: 20.0, discountCash: nil, dish_id: 2, created_at: "2012-03-22 07:42:08", updated_at: "2012-04-16 11:16:49">
1.9.2p290 :131 > pd.discountPercent
=> 20.0
我得到了预期的结果。
但是当我试图获得这样的价值时,
1.9.2p290 :132 > pd1 = PriceDeal.where(:dish_id => 2)
=> [#<PriceDeal id: 17, name: "deal1", description: "my deal1", discountPercent: 20.0, discountCash: nil, dish_id: 2, created_at: "2012-03-22 07:42:08", updated_at: "2012-04-16 11:16:49">]
1.9.2p290 :133 > pd1.discountPercent
NoMethodError: undefined method `discountPercent' for #<ActiveRecord::Relation:0xa134958>
from /home/ragunathjawahar/.rvm/gems/ruby-1.9.2-p290@rails3tutorial/gems/activerecord-3.0.11/lib/active_record/relation.rb:374:in `method_missing'
from (irb):133
from /home/ragunathjawahar/.rvm/gems/ruby-1.9.2-p290@rails3tutorial/gems/railties-3.0.11/lib/rails/commands/console.rb:44:in `start'
from /home/ragunathjawahar/.rvm/gems/ruby-1.9.2-p290@rails3tutorial/gems/railties-3.0.11/lib/rails/commands/console.rb:8:in `start'
from /home/ragunathjawahar/.rvm/gems/ruby-1.9.2-p290@rails3tutorial/gems/railties-3.0.11/lib/rails/commands.rb:23:in `<top (required)>'
from script/rails:6:in `require'
from script/rails:6:in `<main>'
我收到了错误,
如何从pd1获取discountPercent的值。
感谢。
答案 0 :(得分:4)
发生这种情况的原因是因为当您使用where
时,您不会返回PriceDeal
类型的单个对象,而是获得类型为ActiveRecord::Relation
的对象,所有意图和目的都是一个数组。
注意你的表现:
[#<PriceDeal id: 17, name: "deal1", ... >]
而不仅仅是:
#<PriceDeal id: 17, name: "deal1", ... >
大括号([]
)表示它是一个数组。所以你必须这样做:
pd1.first.discountPercent
where
方法返回数组的原因是因为您可以返回多个项目。想象一下:
PriceDeal.where("discountPercent >= 0")
你可能会从那里得到很多记录。
答案 1 :(得分:0)
PD = PriceDeal.find(17)
它只会返回一个特定的列。所以你不会得到任何方法错误。
当你使用Modelname.where(&#34; conditions&#34;)。结果将是array.so你将得到没有方法错误。因为你的方法不存在于数组。