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’以将其更改为英语.

相关文章

项目需要,有个数据需要导入,拿到手一开始以为是mysql,结果...
本文小编为大家详细介绍“怎么查看PostgreSQL数据库中所有表...
错误现象问题原因这是在远程连接时pg_hba.conf文件没有配置正...
因本地资源有限,在公共测试环境搭建了PGsql环境,从数据库本...
wamp 环境 这个提示就是说你的版本低于10了。 先打印ph...
psycopg2.OperationalError: SSL SYSCALL error: EOF detect...