小编Tyl*_*ler的帖子

LIKE 查询的最佳 Postgres 文本索引?

使用 Postgres 9.5,我有一张表addresses

CREATE TABLE addresses (
    id        integer PRIMARY KEY,
    address   text
);
Run Code Online (Sandbox Code Playgroud)

在那个表中,我有 750 万行。例子:

1, "1600 Pennsylvania Avenue NW, Washington, DC, 20500"

我在我的应用程序中使用这个表进行自动建议搜索,所以我需要使用这种类型的查询:

SELECT * FROM addresses WHERE address LIKE '123 Main St%';
Run Code Online (Sandbox Code Playgroud)

我创建了这个索引:

CREATE INDEX address_idx ON addresses (address);
Run Code Online (Sandbox Code Playgroud)

但问题是它需要大约 1 秒,这太慢了。

这是查询计划:

EXPLAIN SELECT * FROM addresses WHERE address LIKE '123 Main St%';
----
Seq Scan on addresses  (cost=0.00..161309.76 rows=740 width=41)
  Filter: (address ~~ '123 Main St%'::text)
Run Code Online (Sandbox Code Playgroud)

我尝试创建几种类型的gin索引,但它们要么没有效果,要么使查询变慢。我不确定我是否正确使用它们。

关于如何创建针对此类查询优化的索引的任何想法?


编辑

迄今为止找到的最佳解决方案是使用文本范围扫描: …

sql postgresql indexing gwt-gin sql-like

7
推荐指数
1
解决办法
6235
查看次数

标签 统计

gwt-gin ×1

indexing ×1

postgresql ×1

sql ×1

sql-like ×1