pg_liquid

pg_liquid

pg_liquid : Liquid-inspired Datalog graph query extension for PostgreSQL

Overview

ID Extension Package Version Category License Language
2705
pg_liquid
pg_liquid
0.1.7
FEAT
MIT
C
Attribute Has Binary Has Library Need Load Has DDL Relocatable Trusted
--s-d--
No
Yes
No
Yes
no
no
Relationships
Schemas liquid
See Also
age
jsquery
pg_jsonschema
pg_search

Packages

Type Repo Version PG Major Compatibility Package Pattern Dependencies
EXT
PIGSTY
0.1.7
18
17
16
15
14
pg_liquid -
RPM
PIGSTY
0.1.7
18
17
16
15
14
pg_liquid_$v -
DEB
PIGSTY
0.1.7
18
17
16
15
14
postgresql-$v-pg-liquid -
Linux / PG PG18 PG17 PG16 PG15 PG14
el8.x86_64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
el8.aarch64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
el9.x86_64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
el9.aarch64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
el10.x86_64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
el10.aarch64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
d12.x86_64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
d12.aarch64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
d13.x86_64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
d13.aarch64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
u22.x86_64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
u22.aarch64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
u24.x86_64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
u24.aarch64
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
PIGSTY 0.1.7
Package Version OS ORG SIZE File URL
pg_liquid_18 0.1.7 el8.x86_64 pigsty 64.7 KiB pg_liquid_18-0.1.7-1PIGSTY.el8.x86_64.rpm
pg_liquid_18 0.1.7 el8.aarch64 pigsty 62.0 KiB pg_liquid_18-0.1.7-1PIGSTY.el8.aarch64.rpm
pg_liquid_18 0.1.7 el9.x86_64 pigsty 62.7 KiB pg_liquid_18-0.1.7-1PIGSTY.el9.x86_64.rpm
pg_liquid_18 0.1.7 el9.aarch64 pigsty 61.8 KiB pg_liquid_18-0.1.7-1PIGSTY.el9.aarch64.rpm
pg_liquid_18 0.1.7 el10.x86_64 pigsty 65.0 KiB pg_liquid_18-0.1.7-1PIGSTY.el10.x86_64.rpm
pg_liquid_18 0.1.7 el10.aarch64 pigsty 62.4 KiB pg_liquid_18-0.1.7-1PIGSTY.el10.aarch64.rpm
postgresql-18-pg-liquid 0.1.7 d12.x86_64 pigsty 383.1 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~bookworm_amd64.deb
postgresql-18-pg-liquid 0.1.7 d12.aarch64 pigsty 378.0 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~bookworm_arm64.deb
postgresql-18-pg-liquid 0.1.7 d13.x86_64 pigsty 383.5 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~trixie_amd64.deb
postgresql-18-pg-liquid 0.1.7 d13.aarch64 pigsty 378.6 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~trixie_arm64.deb
postgresql-18-pg-liquid 0.1.7 u22.x86_64 pigsty 429.6 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~jammy_amd64.deb
postgresql-18-pg-liquid 0.1.7 u22.aarch64 pigsty 427.6 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~jammy_arm64.deb
postgresql-18-pg-liquid 0.1.7 u24.x86_64 pigsty 407.1 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~noble_amd64.deb
postgresql-18-pg-liquid 0.1.7 u24.aarch64 pigsty 402.7 KiB postgresql-18-pg-liquid_0.1.7-1PIGSTY~noble_arm64.deb
Package Version OS ORG SIZE File URL
pg_liquid_17 0.1.7 el8.x86_64 pigsty 64.7 KiB pg_liquid_17-0.1.7-1PIGSTY.el8.x86_64.rpm
pg_liquid_17 0.1.7 el8.aarch64 pigsty 62.0 KiB pg_liquid_17-0.1.7-1PIGSTY.el8.aarch64.rpm
pg_liquid_17 0.1.7 el9.x86_64 pigsty 62.7 KiB pg_liquid_17-0.1.7-1PIGSTY.el9.x86_64.rpm
pg_liquid_17 0.1.7 el9.aarch64 pigsty 61.8 KiB pg_liquid_17-0.1.7-1PIGSTY.el9.aarch64.rpm
pg_liquid_17 0.1.7 el10.x86_64 pigsty 65.0 KiB pg_liquid_17-0.1.7-1PIGSTY.el10.x86_64.rpm
pg_liquid_17 0.1.7 el10.aarch64 pigsty 62.4 KiB pg_liquid_17-0.1.7-1PIGSTY.el10.aarch64.rpm
postgresql-17-pg-liquid 0.1.7 d12.x86_64 pigsty 379.0 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~bookworm_amd64.deb
postgresql-17-pg-liquid 0.1.7 d12.aarch64 pigsty 376.7 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~bookworm_arm64.deb
postgresql-17-pg-liquid 0.1.7 d13.x86_64 pigsty 379.7 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~trixie_amd64.deb
postgresql-17-pg-liquid 0.1.7 d13.aarch64 pigsty 377.4 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~trixie_arm64.deb
postgresql-17-pg-liquid 0.1.7 u22.x86_64 pigsty 450.1 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~jammy_amd64.deb
postgresql-17-pg-liquid 0.1.7 u22.aarch64 pigsty 450.4 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~jammy_arm64.deb
postgresql-17-pg-liquid 0.1.7 u24.x86_64 pigsty 400.9 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~noble_amd64.deb
postgresql-17-pg-liquid 0.1.7 u24.aarch64 pigsty 401.5 KiB postgresql-17-pg-liquid_0.1.7-1PIGSTY~noble_arm64.deb
Package Version OS ORG SIZE File URL
pg_liquid_16 0.1.7 el8.x86_64 pigsty 64.7 KiB pg_liquid_16-0.1.7-1PIGSTY.el8.x86_64.rpm
pg_liquid_16 0.1.7 el8.aarch64 pigsty 62.0 KiB pg_liquid_16-0.1.7-1PIGSTY.el8.aarch64.rpm
pg_liquid_16 0.1.7 el9.x86_64 pigsty 62.7 KiB pg_liquid_16-0.1.7-1PIGSTY.el9.x86_64.rpm
pg_liquid_16 0.1.7 el9.aarch64 pigsty 61.8 KiB pg_liquid_16-0.1.7-1PIGSTY.el9.aarch64.rpm
pg_liquid_16 0.1.7 el10.x86_64 pigsty 64.9 KiB pg_liquid_16-0.1.7-1PIGSTY.el10.x86_64.rpm
pg_liquid_16 0.1.7 el10.aarch64 pigsty 62.4 KiB pg_liquid_16-0.1.7-1PIGSTY.el10.aarch64.rpm
postgresql-16-pg-liquid 0.1.7 d12.x86_64 pigsty 372.0 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~bookworm_amd64.deb
postgresql-16-pg-liquid 0.1.7 d12.aarch64 pigsty 368.1 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~bookworm_arm64.deb
postgresql-16-pg-liquid 0.1.7 d13.x86_64 pigsty 372.4 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~trixie_amd64.deb
postgresql-16-pg-liquid 0.1.7 d13.aarch64 pigsty 368.5 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~trixie_arm64.deb
postgresql-16-pg-liquid 0.1.7 u22.x86_64 pigsty 437.0 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~jammy_amd64.deb
postgresql-16-pg-liquid 0.1.7 u22.aarch64 pigsty 436.2 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~jammy_arm64.deb
postgresql-16-pg-liquid 0.1.7 u24.x86_64 pigsty 393.9 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~noble_amd64.deb
postgresql-16-pg-liquid 0.1.7 u24.aarch64 pigsty 391.3 KiB postgresql-16-pg-liquid_0.1.7-1PIGSTY~noble_arm64.deb
Package Version OS ORG SIZE File URL
pg_liquid_15 0.1.7 el8.x86_64 pigsty 65.4 KiB pg_liquid_15-0.1.7-1PIGSTY.el8.x86_64.rpm
pg_liquid_15 0.1.7 el8.aarch64 pigsty 62.5 KiB pg_liquid_15-0.1.7-1PIGSTY.el8.aarch64.rpm
pg_liquid_15 0.1.7 el9.x86_64 pigsty 64.0 KiB pg_liquid_15-0.1.7-1PIGSTY.el9.x86_64.rpm
pg_liquid_15 0.1.7 el9.aarch64 pigsty 62.8 KiB pg_liquid_15-0.1.7-1PIGSTY.el9.aarch64.rpm
pg_liquid_15 0.1.7 el10.x86_64 pigsty 66.2 KiB pg_liquid_15-0.1.7-1PIGSTY.el10.x86_64.rpm
pg_liquid_15 0.1.7 el10.aarch64 pigsty 63.6 KiB pg_liquid_15-0.1.7-1PIGSTY.el10.aarch64.rpm
postgresql-15-pg-liquid 0.1.7 d12.x86_64 pigsty 370.4 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~bookworm_amd64.deb
postgresql-15-pg-liquid 0.1.7 d12.aarch64 pigsty 367.5 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~bookworm_arm64.deb
postgresql-15-pg-liquid 0.1.7 d13.x86_64 pigsty 370.7 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~trixie_amd64.deb
postgresql-15-pg-liquid 0.1.7 d13.aarch64 pigsty 368.0 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~trixie_arm64.deb
postgresql-15-pg-liquid 0.1.7 u22.x86_64 pigsty 434.7 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~jammy_amd64.deb
postgresql-15-pg-liquid 0.1.7 u22.aarch64 pigsty 435.0 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~jammy_arm64.deb
postgresql-15-pg-liquid 0.1.7 u24.x86_64 pigsty 391.1 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~noble_amd64.deb
postgresql-15-pg-liquid 0.1.7 u24.aarch64 pigsty 391.8 KiB postgresql-15-pg-liquid_0.1.7-1PIGSTY~noble_arm64.deb
Package Version OS ORG SIZE File URL
pg_liquid_14 0.1.7 el8.x86_64 pigsty 65.4 KiB pg_liquid_14-0.1.7-1PIGSTY.el8.x86_64.rpm
pg_liquid_14 0.1.7 el8.aarch64 pigsty 62.6 KiB pg_liquid_14-0.1.7-1PIGSTY.el8.aarch64.rpm
pg_liquid_14 0.1.7 el9.x86_64 pigsty 64.0 KiB pg_liquid_14-0.1.7-1PIGSTY.el9.x86_64.rpm
pg_liquid_14 0.1.7 el9.aarch64 pigsty 62.8 KiB pg_liquid_14-0.1.7-1PIGSTY.el9.aarch64.rpm
pg_liquid_14 0.1.7 el10.x86_64 pigsty 66.1 KiB pg_liquid_14-0.1.7-1PIGSTY.el10.x86_64.rpm
pg_liquid_14 0.1.7 el10.aarch64 pigsty 63.6 KiB pg_liquid_14-0.1.7-1PIGSTY.el10.aarch64.rpm
postgresql-14-pg-liquid 0.1.7 d12.x86_64 pigsty 366.4 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~bookworm_amd64.deb
postgresql-14-pg-liquid 0.1.7 d12.aarch64 pigsty 363.5 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~bookworm_arm64.deb
postgresql-14-pg-liquid 0.1.7 d13.x86_64 pigsty 367.0 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~trixie_amd64.deb
postgresql-14-pg-liquid 0.1.7 d13.aarch64 pigsty 364.5 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~trixie_arm64.deb
postgresql-14-pg-liquid 0.1.7 u22.x86_64 pigsty 427.7 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~jammy_amd64.deb
postgresql-14-pg-liquid 0.1.7 u22.aarch64 pigsty 429.9 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~jammy_arm64.deb
postgresql-14-pg-liquid 0.1.7 u24.x86_64 pigsty 387.5 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~noble_amd64.deb
postgresql-14-pg-liquid 0.1.7 u24.aarch64 pigsty 388.5 KiB postgresql-14-pg-liquid_0.1.7-1PIGSTY~noble_arm64.deb

Source

pig build pkg pg_liquid;		# build rpm/deb

Install

Make sure PGDG and PIGSTY repo available:

pig repo add pgsql -u   # add both repo and update cache

Install this extension with pig:

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

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

Create this extension with:

CREATE EXTENSION pg_liquid;

Usage

Syntax:

CREATE EXTENSION pg_liquid;
SELECT liquid.query('Edge("a","b"). Edge("b","c"). Path(X,Y) :- Edge(X,Y). Path(X,Y) :- Edge(X,Z), Path(Z,Y). Path("a",Y)?');

Sources: README, Docs site

pg_liquid maps the Liquid blog language and data model onto native PostgreSQL storage and execution. The extension exposes SQL entry points for running Liquid-style programs, querying as a principal, and managing row normalizers that project relational rows into Liquid compounds.

Core Functions

The upstream README lists these main functions:

  • liquid.query(program text)
  • liquid.query_as(principal text, program text)
  • liquid.read_as(principal text, program text)

These support plain execution, principal-aware querying, and CLS-aware reads.

Language Features

The current README says supported program features include:

  • % comments
  • assertions and rule definitions terminated with .
  • one terminal ? query
  • Edge(...)
  • named compounds such as Type@(cid=..., role=...)
  • query-local recursive rules

Example Shape

Programs are passed as text and can define facts, rules, and a final query:

SELECT liquid.query($$
  Edge("a","b").
  Edge("b","c").
  Path(X,Y) :- Edge(X,Y).
  Path(X,Y) :- Edge(X,Z), Path(Z,Y).
  Path("a",Y)?
$$);

Notes

The project README points to the VitePress documentation site as the main documentation surface and notes that operational rollout details are also documented there. The extension is currently published as PGXN package version 0.1.1 and validated against PostgreSQL 14 through 18.

Last updated on