Skip to content
plpgsql_check

plpgsql_check

plpgsql_check : extended check for plpgsql functions

Overview

ID Extension Package Version Category License Language
3060
plpgsql_check
plpgsql_check
2.8.11
LANG
MIT
C
Attribute Has Binary Has Library Need Load Has DDL Relocatable Trusted
--sLd--
No
Yes
Yes
Yes
no
no
Relationships
Requires
plpgsql
See Also
pldbgapi
plprofiler
pg_hint_plan
pgtap
auto_explain
plv8
plperl
plpython3u

Packages

Type Repo Version PG Major Compatibility Package Pattern Dependencies
EXT
PGDG
2.8.11
18
17
16
15
14
plpgsql_check plpgsql
RPM
PGDG
2.8.10
18
17
16
15
14
plpgsql_check_$v -
DEB
PGDG
2.8.11
18
17
16
15
14
postgresql-$v-plpgsql-check -
Linux / PG PG18 PG17 PG16 PG15 PG14
el8.x86_64
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
el8.aarch64
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
el9.x86_64
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
el9.aarch64
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
el10.x86_64
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
el10.aarch64
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
PGDG 2.8.10
d12.x86_64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
d12.aarch64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
d13.x86_64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
d13.aarch64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
u22.x86_64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
u22.aarch64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
u24.x86_64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
u24.aarch64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
u26.x86_64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
u26.aarch64
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
PGDG 2.8.11
Package Version OS ORG SIZE File URL
plpgsql_check_18 2.8.10 el8.x86_64 pgdg 116.7 KiB plpgsql_check_18-2.8.10-1PGDG.rhel8.10.x86_64.rpm
plpgsql_check_18 2.8.8 el8.x86_64 pgdg 116.5 KiB plpgsql_check_18-2.8.8-1PGDG.rhel8.10.x86_64.rpm
plpgsql_check_18 2.8.5 el8.x86_64 pgdg 114.2 KiB plpgsql_check_18-2.8.5-1PGDG.rhel8.10.x86_64.rpm
plpgsql_check_18 2.8.4 el8.x86_64 pgdg 113.9 KiB plpgsql_check_18-2.8.4-1PGDG.rhel8.10.x86_64.rpm
plpgsql_check_18 2.8.3 el8.x86_64 pgdg 113.8 KiB plpgsql_check_18-2.8.3-1PGDG.rhel8.x86_64.rpm
plpgsql_check_18 2.8.2 el8.x86_64 pgdg 113.0 KiB plpgsql_check_18-2.8.2-1PGDG.rhel8.x86_64.rpm
plpgsql_check_18 2.8.10 el8.aarch64 pgdg 108.2 KiB plpgsql_check_18-2.8.10-1PGDG.rhel8.10.aarch64.rpm
plpgsql_check_18 2.8.8 el8.aarch64 pgdg 107.9 KiB plpgsql_check_18-2.8.8-1PGDG.rhel8.10.aarch64.rpm
plpgsql_check_18 2.8.5 el8.aarch64 pgdg 105.5 KiB plpgsql_check_18-2.8.5-1PGDG.rhel8.10.aarch64.rpm
plpgsql_check_18 2.8.4 el8.aarch64 pgdg 105.4 KiB plpgsql_check_18-2.8.4-1PGDG.rhel8.10.aarch64.rpm
plpgsql_check_18 2.8.3 el8.aarch64 pgdg 105.2 KiB plpgsql_check_18-2.8.3-1PGDG.rhel8.aarch64.rpm
plpgsql_check_18 2.8.2 el8.aarch64 pgdg 104.4 KiB plpgsql_check_18-2.8.2-1PGDG.rhel8.aarch64.rpm
plpgsql_check_18 2.8.10 el9.x86_64 pgdg 112.4 KiB plpgsql_check_18-2.8.10-1PGDG.rhel9.7.x86_64.rpm
plpgsql_check_18 2.8.8 el9.x86_64 pgdg 112.0 KiB plpgsql_check_18-2.8.8-1PGDG.rhel9.7.x86_64.rpm
plpgsql_check_18 2.8.5 el9.x86_64 pgdg 108.8 KiB plpgsql_check_18-2.8.5-1PGDG.rhel9.7.x86_64.rpm
plpgsql_check_18 2.8.4 el9.x86_64 pgdg 108.7 KiB plpgsql_check_18-2.8.4-1PGDG.rhel9.7.x86_64.rpm
plpgsql_check_18 2.8.3 el9.x86_64 pgdg 109.0 KiB plpgsql_check_18-2.8.3-1PGDG.rhel9.x86_64.rpm
plpgsql_check_18 2.8.2 el9.x86_64 pgdg 108.6 KiB plpgsql_check_18-2.8.2-1PGDG.rhel9.x86_64.rpm
plpgsql_check_18 2.8.10 el9.aarch64 pgdg 107.9 KiB plpgsql_check_18-2.8.10-1PGDG.rhel9.7.aarch64.rpm
plpgsql_check_18 2.8.8 el9.aarch64 pgdg 107.6 KiB plpgsql_check_18-2.8.8-1PGDG.rhel9.7.aarch64.rpm
plpgsql_check_18 2.8.5 el9.aarch64 pgdg 103.6 KiB plpgsql_check_18-2.8.5-1PGDG.rhel9.7.aarch64.rpm
plpgsql_check_18 2.8.4 el9.aarch64 pgdg 103.7 KiB plpgsql_check_18-2.8.4-1PGDG.rhel9.7.aarch64.rpm
plpgsql_check_18 2.8.3 el9.aarch64 pgdg 103.7 KiB plpgsql_check_18-2.8.3-1PGDG.rhel9.aarch64.rpm
plpgsql_check_18 2.8.2 el9.aarch64 pgdg 103.5 KiB plpgsql_check_18-2.8.2-1PGDG.rhel9.aarch64.rpm
plpgsql_check_18 2.8.10 el10.x86_64 pgdg 114.6 KiB plpgsql_check_18-2.8.10-1PGDG.rhel10.1.x86_64.rpm
plpgsql_check_18 2.8.8 el10.x86_64 pgdg 114.7 KiB plpgsql_check_18-2.8.8-1PGDG.rhel10.1.x86_64.rpm
plpgsql_check_18 2.8.5 el10.x86_64 pgdg 111.1 KiB plpgsql_check_18-2.8.5-1PGDGrhel10.1.x86_64.rpm
plpgsql_check_18 2.8.4 el10.x86_64 pgdg 111.2 KiB plpgsql_check_18-2.8.4-1PGDGrhel10.1.x86_64.rpm
plpgsql_check_18 2.8.3 el10.x86_64 pgdg 111.5 KiB plpgsql_check_18-2.8.3-1PGDG.rhel10.x86_64.rpm
plpgsql_check_18 2.8.2 el10.x86_64 pgdg 111.2 KiB plpgsql_check_18-2.8.2-1PGDG.rhel10.x86_64.rpm
plpgsql_check_18 2.8.10 el10.aarch64 pgdg 109.0 KiB plpgsql_check_18-2.8.10-1PGDG.rhel10.1.aarch64.rpm
plpgsql_check_18 2.8.8 el10.aarch64 pgdg 108.7 KiB plpgsql_check_18-2.8.8-1PGDG.rhel10.1.aarch64.rpm
plpgsql_check_18 2.8.5 el10.aarch64 pgdg 105.2 KiB plpgsql_check_18-2.8.5-1PGDGrhel10.1.aarch64.rpm
plpgsql_check_18 2.8.4 el10.aarch64 pgdg 105.2 KiB plpgsql_check_18-2.8.4-1PGDGrhel10.1.aarch64.rpm
plpgsql_check_18 2.8.3 el10.aarch64 pgdg 105.7 KiB plpgsql_check_18-2.8.3-1PGDG.rhel10.aarch64.rpm
plpgsql_check_18 2.8.2 el10.aarch64 pgdg 105.1 KiB plpgsql_check_18-2.8.2-1PGDG.rhel10.aarch64.rpm
postgresql-18-plpgsql-check 2.8.11 d12.x86_64 pgdg 292.6 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg12+1_amd64.deb
postgresql-18-plpgsql-check 2.8.11 d12.aarch64 pgdg 281.5 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg12+1_arm64.deb
postgresql-18-plpgsql-check 2.8.11 d13.x86_64 pgdg 293.1 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg13+1_amd64.deb
postgresql-18-plpgsql-check 2.8.11 d13.aarch64 pgdg 282.5 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg13+1_arm64.deb
postgresql-18-plpgsql-check 2.8.11 u22.x86_64 pgdg 301.7 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg22.04+1_amd64.deb
postgresql-18-plpgsql-check 2.8.11 u22.aarch64 pgdg 291.1 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg22.04+1_arm64.deb
postgresql-18-plpgsql-check 2.8.11 u24.x86_64 pgdg 291.9 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg24.04+1_amd64.deb
postgresql-18-plpgsql-check 2.8.11 u24.aarch64 pgdg 280.7 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg24.04+1_arm64.deb
postgresql-18-plpgsql-check 2.8.11 u26.x86_64 pgdg 290.6 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg26.04+1_amd64.deb
postgresql-18-plpgsql-check 2.8.11 u26.aarch64 pgdg 278.6 KiB postgresql-18-plpgsql-check_2.8.11-1.pgdg26.04+1_arm64.deb

Source

Install

Make sure PGDG repo available:

pig repo add pgdg -u    # add pgdg repo and update cache

Install this extension with pig:

pig install plpgsql_check;		# install via package name, for the active PG version

pig install plpgsql_check -v 18;   # install for PG 18
pig install plpgsql_check -v 17;   # install for PG 17
pig install plpgsql_check -v 16;   # install for PG 16
pig install plpgsql_check -v 15;   # install for PG 15
pig install plpgsql_check -v 14;   # install for PG 14

Config this extension to shared_preload_libraries:

shared_preload_libraries = 'plpgsql_check';

Create this extension with:

CREATE EXTENSION plpgsql_check CASCADE; -- requires plpgsql

Usage

plpgsql_check: extended check for plpgsql functions

plpgsql_check is a linter and checker for PL/pgSQL functions that detects errors at development time rather than runtime.

CREATE EXTENSION plpgsql_check;

Check a Function

SELECT * FROM plpgsql_check_function('my_function()');
SELECT * FROM plpgsql_check_function('my_function(int, text)');
SELECT * FROM plpgsql_check_function('my_function()', fatal_errors := false);

Output Formats

SELECT * FROM plpgsql_check_function('fx()', format := 'text');
SELECT * FROM plpgsql_check_function('fx()', format := 'json');
SELECT * FROM plpgsql_check_function('fx()', format := 'xml');

Check Trigger Functions

-- Trigger functions need the associated table
SELECT * FROM plpgsql_check_function('my_trigger_func()', 'my_table');

-- With transition tables
SELECT * FROM plpgsql_check_function(
  'my_trigger_func()', 'my_table',
  newtable := 'newtab', oldtable := 'oldtab'
);

Warning Categories

SELECT * FROM plpgsql_check_function('fx()',
  extra_warnings := true,         -- dead code, unused parameters
  performance_warnings := true,   -- index and casting issues
  security_warnings := true,      -- SQL injection checks
  compatibility_warnings := true  -- obsolete patterns
);

Batch Check All Functions

SELECT p.oid, p.proname, plpgsql_check_function(p.oid)
FROM pg_catalog.pg_namespace n
JOIN pg_catalog.pg_proc p ON pronamespace = n.oid
JOIN pg_catalog.pg_language l ON p.prolang = l.oid
WHERE l.lanname = 'plpgsql' AND p.prorettype <> 2279;

Passive Mode (Check on Execution)

LOAD 'plpgsql_check';
SET plpgsql_check.mode = 'every_start';  -- check before each execution

Or in postgresql.conf:

shared_preload_libraries = 'plpgsql,plpgsql_check'
plpgsql_check.mode = 'every_start'

Profiler

-- Enable profiling
SELECT plpgsql_check_profiler(true);

-- Execute functions to collect data
SELECT my_function();

-- View per-line execution times
SELECT lineno, avg_time, source
FROM plpgsql_profiler_function_tb('my_function()');

-- Per-statement profile
SELECT stmtid, parent_stmtid, lineno, exec_stmts, stmtname
FROM plpgsql_profiler_function_statements_tb('my_function()');

-- All function statistics
SELECT * FROM plpgsql_profiler_functions_all();

-- Reset profiling data
SELECT plpgsql_profiler_reset_all();

Dependency Tracking

SELECT * FROM plpgsql_show_dependency_tb('my_function(int)');

Coverage Metrics

SELECT * FROM plpgsql_coverage_statements('my_function()');
SELECT * FROM plpgsql_coverage_branches('my_function()');

Pragma Directives

Embed checking options in function comments:

CREATE OR REPLACE FUNCTION fx(anyelement) RETURNS text AS $$
BEGIN
  /* @plpgsql_check_options: anyelementtype = text */
  RETURN $1;
END;
$$ LANGUAGE plpgsql;
Last updated on