5

我已经为我的 Rails 应用程序使用 pg_search gem 实现了全文搜索

我创建索引的迁移看起来像

execute(<<-'eosql'.strip)
  CREATE index mytable_fts_idx
  ON mytable
  USING gin(
    (setweight(to_tsvector('english', coalesce("mytable"."name", '')), 'A') ||
    ' ' ||
    setweight(to_tsvector('english', coalesce("mytable"."description",'')), 'B')
    )
  )
eosql

我的控制器代码看起来像

pg_search_scope :full_text_search,
:against => [
  :name, :description],
:using => {
  :tsearch => {
    :prefix => true,
    :dictionary => "english",
    :any_word => true
  }
}

在 Postgres 9.0.4 上本地运行完全正常。但是,当我将其部署到 heroku 并搜索示例查询“测试”时,它会引发错误

PGError: ERROR:  syntax error in tsquery: "' test ':*"

SELECT COUNT(count_column) FROM (SELECT  1 AS count_column FROM "mytable"  WHERE (((to_tsvector('english', coalesce("mytable"."name", '')) || to_tsvector('english', coalesce("mytable"."description", ''))) @@ (to_tsquery('english', ''' ' || 'test' || ' ''' || ':*')))) LIMIT 12 OFFSET 0) subquery_for_count ):

关于我错在哪里以及我应该如何解决这个错误的任何建议?谢谢。

4

1 回答 1

14

我是pg_search. 很抱歉你遇到了这个问题!现在在对 PostgreSQL 8.3(Heroku 的默认设置)进行搜索pg_search时存在一个错误。:prefix

https://github.com/Casecommons/pg_search/issues/10

这是我现在的首要任务。我仍在寻找让测试套件同时在 8.x 和 9.x 上运行的最佳方法。

更新:不幸的是,:prefix搜索根本不适用于 PostgreSQL 8.3。该功能是在 8.4 中引入的。我发布了pg_search0.3.3 改进了错误消息。希望 Heroku 将很快全面升级到 9.0。我相信他们想这样做,但他们显然不能在没有警告的情况下批发升级每个人。

于 2011-10-05T16:03:42.493 回答