postgresql – 匹配以前缀结尾的短语和全文搜索

postgresql – 匹配以前缀结尾的短语和全文搜索,第1张

概述我正在寻找一种方法来使用PostgreSQL中的tsvector模拟SELECT * FROM table WHERE attr LIKE’%text%’之类的东西. 我没有使用字典就创建了一个tsvector属性.现在,像…这样的查询 SELECT titleFROM tableWHERE title_tsv @@ plainto_tsquery('ph:*'); …将返回所有标题,如’Ph 我正在寻找一种方法来使用Postgresql中的tsvector模拟SELECT * FROM table WHERE attr liKE’%text%’之类的东西.

我没有使用字典就创建了一个tsvector属性.现在,像…这样的查询

SELECT TitleFROM tableWHERE Title_tsv @@ plainto_tsquery('ph:*');

…将返回所有标题,如’Physics’,’PHP’等.但是,如何创建一个返回所有标题的查询,其中标题以’Zend Fram’开头(应该返回例如’Zend Framework’)?

当然,我可以使用类似的东西:

SELECT TitleFROM tableWHERE Title_tsv @@ to_tsquery('Zend')AND   Title_tsv @@ to_tsquery('fram:*');

然而,这似乎有点尴尬.

所以,问题是:有没有办法用以下方法制定上面给出的查询:

SELECT TitleFROM tableWHERE Title_tsv @@ to_tsquery('Zend fram:*');
SELECT TitleFROM tableWHERE Title_tsv @@ to_tsquery('Zend') andTitle_tsv @@ to_tsquery('fram:*')

相当于:

SELECT TitleFROM tableWHERE Title_tsv @@ to_tsquery('Zend & fram:*')

但当然发现“Zend也没有框架”.

当然,你可以在tsquery匹配后表达与标题的正则表达式匹配,但你必须使用explain analyze来确保在tsquery之后而不是之前执行.

总结

以上是内存溢出为你收集整理的postgresql – 匹配以前缀结尾的短语和全文搜索全部内容,希望文章能够帮你解决postgresql – 匹配以前缀结尾的短语和全文搜索所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1164842.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-01
下一篇 2022-06-01

发表评论

登录后才能评论

评论列表(0条)

保存