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’以将其更改为英语. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |