Думающий Сфинкс - Показ правильной записи из ассоциации - PullRequest
0 голосов
/ 30 мая 2011

Я успешно получил Thinking Sphinx, работающий с Geolocation над связанной моделью. Счастливые дни!

Но теперь мне нужно, чтобы он отображал правильную связанную запись на карте Google.

Сценарий - компания с офисами has_many. Офисы имеют значения lng, lat. Я ищу компанию и связываю с ней офисы.

1007 * Е.Г. *

  define_index do

 indexes :name, :sortable => true
 indexes offices(:city), :as => :city
 indexes offices(:postal_code), :as => :postal_code

 has "RADIANS(offices.lat)", :as => :lat,  :type => :float
 has "RADIANS(offices.lng)", :as => :lng,  :type => :float

 has created_at
 has updated_at

 set_property :latitude_attr  => 'lat'
 set_property :longitude_attr => 'lng'
 set_property :field_weights  => { 'name'        => 10,
                                  'service_name' => 9,
                                  'city'    => 8 }

 end

Поиск x компании в y месте / почтовом индексе работает отлично, показывая правильные компании, у которых есть офисы в нужном месте в радиусе @geodist.

1012 * Е.Г. *

{:geo=>[0.9283660690549609, -0.050527407508941975], :sort_mode=>:expr, :sort_by=>"@weight * @weight / @geodist", :with=>{"@geodist"=>0.0..120700.8}, :conditions=>{:service_name=>"Business strategies"}, :page=>1, :per_page=>12, :star=>true}

Полученные записи являются объектом компании, а не офисами, что хорошо для представления списка, но я хочу показать значки на карте Google соответствующего связанного офиса.

Как лучше всего найти соответствующую запись в офисе, чтобы показать ее в пределах радиуса?

1 Ответ

0 голосов
/ 30 мая 2011

Sphinx надежно обрабатывает только плавающие атрибуты с одним значением - и у него нет понятия парных значений lat / lng. Это означает, что вы не можете осуществлять тщательный поиск по объектам с более чем одной парой широта / долгота.

Лучший обходной путь - вместо этого поискать в Office - и, возможно, получить информацию о компании каждого офиса:

define_index do
  indexes company.name, :as => :name, :sortable => true
  indexes city, postal_code

  has "RADIANS(offices.lat)", :as => :lat,  :type => :float
  has "RADIANS(offices.lng)", :as => :lng,  :type => :float
  has company.created_at, :as => :created_at
  has company.updated_at, :as => :updated_at
  has company_id

  set_property :field_weights  => {
    'name'         => 10,
    'service_name' => 9,
    'city'         => 8
  }
end

И затем при поиске вы можете сгруппировать по company_id, чтобы обеспечить только один результат для любой компании (если это то, что вы предпочитаете):

Office.search 'foo',
  :geo            => [lat, lng],
  :with           => {'@geodist' => 0.0..120700.8}
  :group_function => :attr
  :group_by       => 'company_id'

Если важно, какой Office будет возвращен для данного идентификатора компании, то вы, вероятно, также захотите использовать параметр :group_clause. Документы охватывают это .

...