加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

PostgreSQL上的全文搜索

发布时间:2020-12-13 16:05:42 所属栏目:百科 来源:网络整理
导读:现在我正在学习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 PROCEDUREtsvecto
现在我正在学习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’以将其更改为英语.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读