These examples should have proven to you that looking at the counts of blocks hit and read is valuable for determining whether a query plan is really being executed correctly or not. PostgreSQL 9.0 adds a feature to make this easier than before. Rather than looking at the pg_stat* data as done in the preceding example, you can request a count of buffers accessed directly when running EXPLAIN:
data:image/s3,"s3://crabby-images/4a38a/4a38acc0163b970965081fc5b9aa1f7292f2f513" alt=""
To see how well this works, try running that query again after dropping the index that's selective on v:
data:image/s3,"s3://crabby-images/1097a/1097afcdd9b53daa011b97d480b512d2d9732968" alt=""
That shows the sequential scan running against the full 443 pages of data this table is known to occupy, instead of the much smaller count the earlier query executed in.