我正在寻找一种方法来使用Postgresql中的tsvector模拟SELECT * FROM table WHERE attr LIKE’%text%’之类的东西.
我没有使用字典就创建了一个tsvector属性.现在,像…这样的查询
SELECT title FROM table WHERE title_tsv @@ plainto_tsquery('ph:*');
…将返回所有标题,如’Physics’,’PHP’等.但是,如何创建一个返回所有标题的查询,其中标题以’Zend Fram’开头(应该返回例如’Zend Framework’)?
当然,我可以使用类似的东西:
SELECT title FROM table WHERE title_tsv @@ to_tsquery('zend') AND title_tsv @@ to_tsquery('fram:*');
然而,这似乎有点尴尬.
SELECT title FROM table WHERE title_tsv @@ to_tsquery('zend fram:*');
SELECT title FROM table WHERE title_tsv @@ to_tsquery('zend') and title_tsv @@ to_tsquery('fram:*')
相当于:
SELECT title FROM table WHERE title_tsv @@ to_tsquery('zend & fram:*')
但当然发现“Zend也没有框架”.
当然,你可以在tsquery匹配后表达与标题的正则表达式匹配,但你必须使用explain analyze来确保在tsquery之后而不是之前执行.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。