这就是我想做的事情:查找是否有人在推特上发布了有关所提供的特定课程的信息。如果有人确实发布了关于它的推文,我想将该推文保存到我的推文模型中,然后在相应的课程页面中显示该推文。
脚本通过运行在本地工作,rails runner get_tweets.rb
但在 Heroku 上似乎脚本被执行但不写入数据库。在 heroku 我正在运行heroku run rails runner get_tweets.rb
(使用 Cedar 堆栈)。
def get_course_tweets
@courses = Course.all
@courses.each do |course|
url = course.url
tweets = Twitter.search(url, {:rpp => 100, :recent => true, :show_user => true})
tweets.each do |tweet_info|
unless Tweet.find_by_tweet_id(tweet_info.id).present?
tweet = Tweet.new
tweet.course_id = course.id
tweet.tweet_id = tweet_info.id
tweet.tweet_text = tweet_info.text
tweet.from_user = tweet_info.from_user
begin
tweet.save!
rescue => error
puts error
end
end
end
end
end
编辑:
我从救援中得到的当前错误如下:
PG::Error: ERROR: value "186306985577299969" is out of range for type integer : INSERT INTO "tweets" ("book_id", "course_id", "created_at", "from_user", "tutorial_id", "tweet_already_exists", "tweet_id", "tweet_posted_to_reviews", "tweet_text", "updated_at") VALUES ($1, $2, $3, $4, $5, $6, $7, $8, $9, $10) RETURNING "id"