mirror of
https://git.postgresql.org/git/postgresql.git
synced 2024-10-10 10:16:52 +02:00
31 lines
1.1 KiB
MySQL
31 lines
1.1 KiB
MySQL
|
/* contrib/pg_buffercache/pg_buffercache--1.3--1.4.sql */
|
||
|
|
||
|
-- complain if script is sourced in psql, rather than via ALTER EXTENSION
|
||
|
\echo Use "ALTER EXTENSION pg_buffercache UPDATE TO '1.4'" to load this file. \quit
|
||
|
|
||
|
/* First we have to remove them from the extension */
|
||
|
ALTER EXTENSION pg_buffercache DROP VIEW pg_buffercache;
|
||
|
ALTER EXTENSION pg_buffercache DROP FUNCTION pg_buffercache_pages();
|
||
|
|
||
|
/* Then we can drop them */
|
||
|
DROP VIEW pg_buffercache;
|
||
|
DROP FUNCTION pg_buffercache_pages();
|
||
|
|
||
|
/* Now redefine */
|
||
|
CREATE FUNCTION pg_buffercache_pages()
|
||
|
RETURNS SETOF RECORD
|
||
|
AS 'MODULE_PATHNAME', 'pg_buffercache_pages_v1_4'
|
||
|
LANGUAGE C PARALLEL SAFE;
|
||
|
|
||
|
CREATE VIEW pg_buffercache AS
|
||
|
SELECT P.* FROM pg_buffercache_pages() AS P
|
||
|
(bufferid integer, relfilenode int8, reltablespace oid, reldatabase oid,
|
||
|
relforknumber int2, relblocknumber int8, isdirty bool, usagecount int2,
|
||
|
pinning_backends int4);
|
||
|
|
||
|
-- Don't want these to be available to public.
|
||
|
REVOKE ALL ON FUNCTION pg_buffercache_pages() FROM PUBLIC;
|
||
|
REVOKE ALL ON pg_buffercache FROM PUBLIC;
|
||
|
GRANT EXECUTE ON FUNCTION pg_buffercache_pages() TO pg_monitor;
|
||
|
GRANT SELECT ON pg_buffercache TO pg_monitor;
|