如何解决rails控制台中丢失错误的方法

时间:2012-04-16 13:58:36

标签: ruby-on-rails ruby-on-rails-3

我有一个模型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的值。

感谢。

2 个答案:

答案 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你将得到没有方法错误。因为你的方法不存在于数组。