File: buffercache_pgfincore.sql

package info (click to toggle)
pgfincore 1.1.2-3
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 172 kB
  • ctags: 82
  • sloc: ansic: 610; sql: 263; makefile: 93; sh: 2
file content (47 lines) | stat: -rw-r--r-- 1,081 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
with my_table as (
  select oid
       , relfilenode
       , relname
  from pg_class
  where relname = 'pgbench_accounts'
)
, t as (
  select generate_series(1, relpages) as g
  from my_table
  join pg_class using (relname)
)
, buf as (
  select relblocknumber * 2 as bn -- Pgfincore use filesystem block size
       , usagecount as c
       , isdirty as d
  from my_table
  join pg_buffercache using (relfilenode)
  where relforknumber = 0
)
, pgf as (
  select (row_number() over (partition by c)) - 1 as bn -- pascal vs C
  	   , c
	   , NULL as d
  from (select unnest(
                      string_to_array(
			               (pgfincore(my_table.oid, true)).databit::text, NULL
			          )
               ) as c 
        from my_table ) g
)
, fb as (
   select pgf.bn as file_block_number
       	, buf.c as pgcache
      	, buf.d as pgdirty
        , pgf.c as oscache
        , pgf.d as osdirty
  from buf 
  right join pgf using (bn)
  order by 1, 2, 3
),
res as (
  select *
  from fb
)
select row_to_json(res) -- use "res" CTE if no JSON datatype (pg < 9.2)
from res;