微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

PostgreSQL上的全文搜索

现在我正在学习Postgresql 9.2.3中的全文搜索.但是,我有一个问题.我运行这个例子:

CREATE TABLE messages (title text,body text,tsv tsvector);

CREATE TRIGGER tsvectorupdate 
BEFORE INSERT OR UPDATE ON messages FOR EACH ROW EXECUTE PROCEDURE
tsvector_update_trigger(tsv,'pg_catalog.english',title,body);

INSERT INTO messages VALUES('title here','the body text is here');

不幸的是,之后:

SELECT title,body FROM messages WHERE tsv @@ to_tsquery('title & body')

我没有得到结果 – 返回了0行.你能告诉我为什么吗?根据Postgresql的文档,它应该工作.

只有’titl’和’bodi’作为查询才能得到合适的结果.为什么?

解决方法

只有一个参数的to_tsquery使用认的文本搜索配置,在您的情况下看起来不是英文.

您可以使用带有显式文本配置的表单来获得预期结果:

SELECT title,body FROM messages
  WHERE tsv @@ to_tsquery('english','title & body')

sql中使用SHOW default_text_search_config来查看有效的文本配置是什么,并将SET default_text_search_config设置为’english’以将其更改为英语.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐