A fast, user friendly ORM and query builder which supports asyncio.
Project description
Piccolo
A fast, user friendly ORM and query builder which supports asyncio. Read the docs.
Features
Some of it’s stand out features are:
- Support for sync and async.
- A builtin playground, which makes learning a breeze.
- Tab completion support - works great with iPython and VSCode.
- Batteries included - a User model, authentication, migrations, an admin GUI, and more.
- Modern Python - fully type annotated.
Syntax
The syntax is clean and expressive.
You can use it as a query builder:
# Select:
await Band.select(
Band.name
).where(
Band.popularity > 100
).run()
# Join:
await Band.select(
Band.name,
Band.manager.name
).run()
# Delete:
await Band.delete().where(
Band.popularity < 1000
).run()
# Update:
await Band.update({Band.popularity: 10000}).where(
Band.name == 'Pythonistas'
).run()
Or like a typical ORM:
# To create a new object:
b = Band(name='C-Sharps', popularity=100)
await b.save().run()
# To fetch an object from the database, and update it:
b = await Band.objects().where(Band.name == 'Pythonistas').first().run()
b.popularity = 10000
await b.save().run()
# To delete:
await b.remove().run()
Installation
pip install piccolo
Building a web app?
Let Piccolo scaffold you an ASGI web app, using Piccolo as the ORM:
piccolo asgi new
Starlette and FastAPI are currently supported.
Are you a Django user?
We have a handy page which shows the equivalent of common Django queries in Piccolo.
Documentation
See Read the docs.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
piccolo-0.14.6.tar.gz
(99.0 kB
view hashes)
Built Distribution
piccolo-0.14.6-py3-none-any.whl
(157.8 kB
view hashes)