data:image/s3,"s3://crabby-images/3de46/3de4693e697c47cd537c7068c1084aa7c358c80d" alt="Cache id is hidden from other users"
data:image/s3,"s3://crabby-images/cd6c4/cd6c47b75f72456ce77a03e00b4b6e6fd7b9c350" alt="cache id is hidden from other users cache id is hidden from other users"
It took 160 ms since there was disk I/O involved to fetch those records from disk.Įxecution is faster if same query is re-executed, as all the blocks are still in cache of PostgreSQL server at this stage SELECT pg_stat_reset() Īggregate (cost=1747.34 rows=1 width=8) (actual time=33.760.33.761 rows=1 loops=1)
data:image/s3,"s3://crabby-images/88f71/88f71b18c6fdccfaff56b7a65563a5b5e4e56307" alt="cache id is hidden from other users cache id is hidden from other users"
In the above example, there were 1000 blocks read from the disk to find count tuples where c_id = 1. Then check the blocks read from the disk SELECT heap_blks_read, heap_blks_hit from pg_statio_user_tables where relname='tbldummy' Now execute a query and check for the time taken to execute the same SELECT pg_stat_reset() ĮXPLAIN ANAYZE SELECT count(*) from tbldummy where c_id=1 Īggregate (cost=1747.34 rows=1 width=8) (actual time=160.269.160.269 rows=1 loops=1) VALUES (p_id_ctr,c_id_ctr,'now', random_value, CONCAT('Description for :',p_id_ctr, c_id_ctr)) INSERT INTO tblDummy (p_id,c_id,entry_time, entry_value, description ) Populate dummy data with 200000 tuples, such that there are 10000 unique p_id and for every p_id there are 200 c_id DO $$ Start PostgreSQL keeping shared_buffer set to default 128 MB $ initdb -D $/data/nfĬonnect to the server and create a dummy table tblDummy and an index on c_id CREATE Table tblDummy
data:image/s3,"s3://crabby-images/35273/352731270a3c531c00fd2ae89b8bef0a58e809d9" alt="cache id is hidden from other users cache id is hidden from other users"
Let’s execute an example and see the impact of cache on the performance. In other words, a page which is accessed only once has higher chances of eviction (as compared to a page which is accessed multiple times), in case a new page needs to be fetched by PostgreSQL into cache. At a high level, PostgreSQL follows LRU (least recently used) algorithm to identify the pages which need to be evicted from the cache.
data:image/s3,"s3://crabby-images/3de46/3de4693e697c47cd537c7068c1084aa7c358c80d" alt="Cache id is hidden from other users"