Skip to content

PostgREST client for Python. This library provides an ORM interface to PostgREST

License

Notifications You must be signed in to change notification settings

supabase/postgrest-py

Folders and files

NameName
Last commit message
Last commit date

Latest commit

6b21124 · Mar 25, 2025
Jan 4, 2022
Jan 30, 2025
Oct 18, 2024
Mar 24, 2025
Mar 25, 2025
Mar 24, 2025
Feb 29, 2024
Jan 30, 2025
Apr 18, 2022
Mar 25, 2025
Mar 25, 2025
Jan 4, 2022
Jan 4, 2022
Aug 20, 2024
Jan 23, 2025
Oct 15, 2024
Mar 25, 2025
Mar 25, 2025
Aug 14, 2024

Repository files navigation

postgrest-py

PostgREST client for Python. This library provides an "ORM-like" interface to PostgREST.

INSTALLATION

Requirements

  • Python >= 3.9
  • PostgreSQL >= 13
  • PostgREST >= 11

Local PostgREST server

If you want to use a local PostgREST server for development, you can use our preconfigured instance via Docker Compose.

docker-compose up

Once Docker Compose started, PostgREST is accessible at http://localhost:3000.

Instructions

With Poetry (recommended)

poetry add postgrest

With Pip

pip install postgrest

USAGE

Getting started

import asyncio
from postgrest import AsyncPostgrestClient

async def main():
    async with AsyncPostgrestClient("http://localhost:3000") as client:
        r = await client.from_("countries").select("*").execute()
        countries = r.data

asyncio.run(main())

Create

await client.from_("countries").insert({ "name": "Việt Nam", "capital": "Hà Nội" }).execute()

Read

r = await client.from_("countries").select("id", "name").execute()
countries = r.data

Update

await client.from_("countries").update({"capital": "Hà Nội"}).eq("name", "Việt Nam").execute()

Delete

await client.from_("countries").delete().eq("name", "Việt Nam").execute()

General filters

Stored procedures (RPC)

await client.rpc("foobar", {"arg1": "value1", "arg2": "value2"}).execute()

DEVELOPMENT

git clone https://github.com/supabase/postgrest-py.git
cd postgrest-py
poetry install
poetry run pre-commit install

Testing

poetry run pytest

CHANGELOG

Read more here.

SPONSORS

We are building the features of Firebase using enterprise-grade, open source products. We support existing communities wherever possible, and if the products don’t exist we build them and open source them ourselves. Thanks to these sponsors who are making the OSS ecosystem better for everyone.

Worklife VC New Sponsor