8

我正在使用 Ruby (1.9.3) 和 Rails (3.2.2)。我有一个任务文件,其中包含一堆要填充到我的数据库中的假数据。

这是我认为导致问题的任务的一部分

#Create random Tender and populate the db
     20.times do |n|
      title  = "#{Faker::Company.bs()} tender "
      company_name = Faker::Company.name
      opening_date=Time.at(rand * Time.now.to_i)
      closing_date=Time.at(opening_date + ( 8*7*24*60*60)) #add 8 weeks to the deadline
      bid_amount= rand(10000..100000)
      description=Faker::Lorem.paragraph(sentence_count = 3)


      Tender.create!(title: title,
                   company_name: company_name,
                   opening_date: opening_date,
                   closing_date: closing_date,
           bid_amount: bid_amount    ,
           bid_amount: bid_amount    ,
           description: description )
    end

它适用于 dev,但只有上述部分不在生产数据库上执行。我 gem 'sqlite3', '1.3.5'在开发中使用。和

gem 'pg', '0.12.2'在生产中(heroku)

当我跑

git push heroku
$ heroku pg:reset SHARED_DATABASE --confirm myapp
$ heroku run rake db:migrate
$ heroku run rake db:populate

db:populate throws an error that says **can't covert Range to Integer.**

任何想法可能是什么问题?

编辑: bid_amount 的数据类型是decimal

4

1 回答 1

8

您的生产 ruby​​ 版本不是 1.9.3。大概是1.8.7

$ ruby -v
ruby 1.8.7 (2010-01-10 patchlevel 249) [universal-darwin11.0]
$ irb
>> rand(10000..100000)
TypeError: can't convert Range into Integer
    from (irb):1:in `rand'
    from (irb):1
>> exit
$ rvm use 1.9.3
Using /Users/chirantan/.rvm/gems/ruby-1.9.3-p0
$ irb
1.9.3p0 :001 > rand(10000..100000)
 => 37036 

在生产环境中安装 ruby​​ 1.9.3,rand 方法应该可以正常工作。

于 2012-06-15T16:03:59.557 回答