我在Postgres数据库的SELECT查询中遇到了速度问题.
我有一个表,有两个整数列作为键:(int1,int2)
在此环境中,我需要进行两种简单的SELECT查询:
SELECT * FROM table WHERE int1=X;
SELECT * FROM table WHERE int2=X;
这两个 Select 在这7000万行中返回大约10000行.为了让它尽可能快地工作,我考虑使用两个哈希索引,每列一个.不幸的是,结果并不是那么好:
QUERY PLAN
----------------------------------------------------------------------------------------------------------------------------------------
Bitmap Heap Scan on lec_sim (cost=232.21..25054.38 rows=6565 width=36) (actual time=14.759..23339.545 rows=7871 loops=1)
Recheck Cond: (lec2_id = 11782)
-> Bitmap Index Scan on lec_sim_lec2_hash_ind (cost=0.00..230.56 rows=6565 width=0) (actual time=13.495..13.495 rows=7871 loops=1)
Index Cond: (lec2_id = 11782)
Total runtime: 23342.534 ms
(5 rows)
这是其中一个查询的解释分析示例.大约需要23秒.我的期望是在不到一秒钟内得到这些信息.
以下是postgres db配置的一些参数:
work_mem = 128MB
shared_buffers = 2GB
maintenance_work_mem = 512MB
fsync = off
synchronous_commit = off
effective_cache_size = 4GB
任何帮助、 comments 或 idea 都将不胜感激.
提前谢谢你.