pyrsql¶
A compiler-oriented RSQL query engine for safe, typed, and extensible filtering, sorting, and pagination in Python APIs.
pyrsql compiles RSQL query strings into ORM-specific statement objects through a multi-stage pipeline - making it easy to expose complex query capabilities in your API without coupling to a specific ORM or framework.
Install¶
First query¶
import pyrsql
from sqlalchemy import select
from pyrsql.orms.sqlalchemy import SQLAlchemyORM
orm = SQLAlchemyORM()
stmt = pyrsql.parse("name==demo;age=gt=18").apply(select(User), User, orm=orm)
Key features¶
- ORM-neutral core -
Query,Sort,PageRequesthave zero ORM dependencies - Pluggable backends - SQLAlchemy 2.0 today, Django ORM / SQLModel planned
- Pluggable adapters - FastAPI today, Flask planned
- 20+ built-in operators -
==,=like=,=in=,=bt=,=nn=, etc. - Custom operators - define your own RSQL operators with per-ORM lowering
- Field policies - whitelist, blacklist, aliases (global + per-model)
- JSON / JSONB - PostgreSQL
jsonpathwith structured values and datetime support - Type-safe - strict mypy, Google-style docstrings, immutable value objects