我与Ruby on Rails 4
进行了Thinking Sphinx 3
项目。我的模特很少:
class Investment < ActiveRecord::Base
has_many :investment_parts
end
class InvestmentPart < ActiveRecord::Base
belongs_to :investment
has_many :check_orders, dependent: :destroy
has_many :legal_entity_insurance_companies, through: :check_orders, class_name: "LegalEntities::InsuranceCompany"
end
class CheckOrder < ActiveRecord::Base
belongs_to :legal_entity_insurance_company, class_name: "LegalEntities::InsuranceCompany"
belongs_to :investment_part
end
我需要通过CheckOrders找到Investmens,它有布尔字段approved
。
create_table "check_orders", force: true do |t|
...
t.boolean "approved", default: false
end
所以我试过了:
ThinkingSphinx::Index.define :investment, with: :active_record do
indexes investment_parts.check_orders.approved, as: :insuranced_investment
end
但搜索一无所获:
2.0.0p353 :008 > CheckOrder.pluck(:approved)
(0.6ms) SELECT "check_orders"."approved" FROM "check_orders"
=> [true, true, true]
2.0.0p353 :009 > Investment.search("", conditions: {insuranced_investment: true})
Sphinx Retrying query "SELECT * FROM `investment_core` WHERE MATCH('@insuranced_investment true') AND `sphinx_deleted` = 0 LIMIT 0, 20 OPTION max_matches=50000; SHOW META" after error: Lost connection to MySQL server during query
Sphinx Query (3.5ms) SELECT * FROM `investment_core` WHERE MATCH('@insuranced_investment true') AND `sphinx_deleted` = 0 LIMIT 0, 20 OPTION max_matches=50000
Sphinx Found 0 results
=> []
所以我决定尝试属性过滤器:
ThinkingSphinx::Index.define :investment, with: :active_record do
has investment_parts.check_orders.approved, as: :insuranced_investment_attr
end
但它会产生错误:
$ rake ts:rebuild
Stopped searchd daemon (pid: 15516).
Generating configuration to /Projects/my-project/config/development.sphinx.conf
Sphinx 2.1.4-release (rel21-r4421)
...
using config file '/Projects/my-project/config/development.sphinx.conf'...
...
indexing index 'investment_core'...
ERROR: source 'investment_core_0': expected attr type ('uint' or 'timestamp' or 'bigint') in sql_attr_multi, got 'bool insuranced_investment_attr from field'.
ERROR: index 'investment_core': failed to configure some of the sources, will not index.
...
total 15 reads, 0.000 sec, 0.7 kb/call avg, 0.0 msec/call avg
total 50 writes, 0.000 sec, 0.5 kb/call avg, 0.0 msec/call avg
Started searchd successfully (pid: 15556).
我该如何解决?
答案 0 :(得分:2)
Daiku是正确的,属性可以更好地满足您的需求,但事实是Sphinx无法处理boolean类型的多值属性。
因此,需要进行一些解决方法 - 您希望确保包含check_orders的连接,然后您想要将一个SQL片段转换为整数的布尔值(true为1,false为0)。我认为以下应该可以解决问题(选择您正在使用的数据库的选项):
join investment_parts.check_orders
# for PostgreSQL:
has "array_to_string(array_agg(DISTINCT (CASE check_orders.approved THEN 1 ELSE 0 END)), ',')",
as: :insuranced_investment_attr, type: :integer, multi: true
# for MySQL:
has "GROUP_CONCAT(DISTINCT (CASE check_orders.approved THEN 1 ELSE 0 END) SEPARATOR ',')",
as: :insuranced_investment_attr, type: :integer, multi: true
答案 1 :(得分:0)
属性过滤器绝对是布尔字段的方法。尝试告诉sphinx属性类型:
has investment_parts.check_orders.approved, as: :insuranced_investment_attr, type: :boolean