从
this answer开始,我想知道使用Postgresql内置全文搜索的最佳方法是,如果我想按排序排序,并限制为仅匹配查询.
我们假设一个非常简单的表.
CREATE TABLE pictures { id SERIAL PRIMARY KEY,title varchar(300),... }
CREATE INDEX pictures_title ON pictures USING gin(to_tsvector('english',title));
现在我想搜索“小狗”.这样做:
SELECT pictures.id,ts_rank_cd(to_tsvector('english',pictures.title),'small dog') AS score FROM pictures ORDER BY score DESC
但我真正想要的是这样的:
SELECT pictures.id,to_tsquery('small dog')) AS score FROM pictures WHERE to_tsvector('english',pictures.title) @@ to_tsquery('small dog') ORDER BY score DESC
或者这个(不行 – 不能在WHERE子句中使用分数):
SELECT pictures.id,to_tsquery('small dog')) AS score FROM pictures WHERE score > 0 ORDER BY score DESC
最好的方法是什么?我的问题是多重的:
>如果我使用带有重复的to_tsvector(…)的版本,它会调用两次,还是足够聪明地缓存结果?
>有没有办法做,而不重复to_ts …函数调用?
>有没有办法在WHERE子句中使用得分?
>如果有的话,最好是通过得分> 0或使用@@东西?