我有一个使用ActiveRecord和Sinatra访问的MYSQL数据库。我正在尝试对表中的记录执行某些地理位置任务。
但是,我认为我的语法是错误的,因为扩展地理编码器类会使我的CRUD请求失败:
myapp.rb
require 'rubygems'
require 'sinatra'
require 'active_record'
require 'table_print'
require 'json'
ActiveRecord::Base.establish_connection(
:adapter => "mysql2",
:host => "localhost",
:username => "root",
:database => "orbital"
)
class Post < ActiveRecord::Base
extend Geocoder::Model::ActiveRecord
# attr_accessor :latitude, :longitude
end
class Comment < ActiveRecord::Base
#extend Geocoder::Model::ActiveRecord
end
class MyApp < Sinatra::Application
#extend Geocoder::Model::ActiveRecord
end
post '/post' do
@user = params[:user]
@content = params[:content]
@latitude = params[:latitude]
@longitude = params[:longitude]
@timestamp = params[:timestamp]
record = Post.create(user: @user, content: @content, longitude: @longitude, latitude: @latitude, timestamp: @timestamp)
record.save
end
我要执行的查询是:
Post.near([@lat, @long], @dist, units: :km).offset(10 * @var.to_i).first(10)
此stackoverflow线程here还建议我需要设置其他参数,例如attr_accessors
。我该如何设置上面的代码,以便可以使用Geocoder的near
方法?
答案 0 :(得分:1)
我通过添加以下内容解决了上述问题:
1.04166666666667E-02
和
"00:15:00"