我正在构建一个 Ruby on Rails 应用程序,它利用 Mongoid gem 通过 Mongodb 存储数据。
我的问题来自这个 rake 任务:
require 'rubygems'
require 'nokogiri'
require 'open-uri'
task :scrape => :environment do
page = Nokogiri::HTML(open('https://maps.google.com/maps/ms?ie=UTF8&hl=en&source=embed&dg=feature&authuser=0&msa=0&output=kml&msid=208523333872813891131.0004c02beb4f2788337d0'))
page.css("coordinates").each do |coords|
coords = coords.text.split("\n")
coords.each do |coord|
array = coord.strip.split(',')
array[0] = array[0].to_f
array[1] = array[1].to_f
if (array[0] != 0 && array[1] !=0)
puts array[0]
puts array[1]
s = Submission.new(array[0], array[1], "Calfire", nil)
s.insert
end
end
end
end
s.insert
尝试将从 URL 中获取的信息,创建一个 Submission
的实例,然后将其插入到 Mongodb 数据库中。每次我在终端运行 rake scrape
时,我都会收到以下错误,因为它试图将 Submission
保存在数据库中。
-122.952888
40.741924
rake aborted!
Moped::Errors::OperationFailure: The operation: #<Moped::Protocol::Command
@length=83
@request_id=3
@response_to=0
@op_code=2004
@flags=[]
@full_collection_name="fireapp_development.$cmd"
@skip=0
@limit=-1
@selector={:getlasterror=>1, :w=>1}
@fields=nil>
failed with error 13066: "Message contains no documents"
我对 Ruby 和 Mongodb 都很陌生,所以如果任何其他代码有帮助,它可以用它来更新这篇文章。我尝试设置一个新的应用程序/脚手架,看看是否可以解决它,但没有任何改变。我还尝试通过终端保存 Submission
的实例,但这也没有用。
在谷歌搜索解决方案时,我遇到了这个讨论: https://groups.google.com/forum/#!topic/mongodb-user/kg-wK56_JkQ
这表明我可能没有查询任何内容,但 Ruby 代码中的 puts
行清楚地输出到终端。非常感谢任何帮助。
编辑 1:
提交
模型的字段
class Submission
include Mongoid::Document
field :lat, type: Float
field :long, type: Float
field :image, type: Moped::BSON::Binary
field :category, type: String
end
编辑 2:
问题已通过正确格式化 s.create
行以及删除 s.insert
行得到解决。
最佳答案
标准用法是Model.create(attributes)
,你应该这样做:
s = Submission.create(:lat => array[0], :long => array[1], :category => 'Calfire')
# No Submission.new, no s.insert, just create and check s.valid? or use create!
我怀疑 Submission.new
并不知道如何处理所有这些位置参数,所以您可能在 s
中遇到了一些令人困惑的废话。可推测的 Submission.new
正在尝试解释参数并默默地失败。
关于ruby-on-rails - 尝试插入 Mongodb 时出现 "Message Contains No Documents",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25537983/