Databases + asyncio.
Project description
Databases
Databases gives you simple asyncio support for a range of databases.
Currently PostgreSQL and MySQL are supported.
Requirements: Python 3.6+
Installation
$ pip install databases
You can install the required database drivers with:
$ pip install databases[postgresql]
$ pip install databases[mysql]
Getting started
Declare your tables using SQLAlchemy:
import sqlalchemy
metadata = sqlalchemy.MetaData()
notes = sqlalchemy.Table(
"notes",
metadata,
sqlalchemy.Column("id", sqlalchemy.Integer, primary_key=True),
sqlalchemy.Column("text", sqlalchemy.String(length=100)),
sqlalchemy.Column("completed", sqlalchemy.Boolean),
)
You can use any of the sqlalchemy column types such as sqlalchemy.JSON
, or
custom column types.
Queries
You can now use any SQLAlchemy core queries:
from databases import Database
database = Database('postgresql://localhost/example')
# Establish the connection pool
await database.connect()
# Execute
query = notes.insert()
values = {"text": "example1", "completed": True}
await database.execute(query, values)
# Execute many
query = notes.insert()
values = [
{"text": "example2", "completed": False},
{"text": "example3", "completed": True},
]
await database.execute_many(query, values)
# Fetch multiple rows
query = notes.select()
rows = await database.fetch_all(query)
# Fetch single row
query = notes.select()
row = await database.fetch_one(query)
Transactions
Transactions are managed by async context blocks:
async with database.transaction():
...
For a lower-level transaction API:
transaction = await database.transaction()
try:
...
except:
transaction.rollback()
else:
transaction.commit()
For strict test isolation you will always want to rollback the test database to a clean state between each test case:
async with database.transaction(force_rollback=True):
...
Transaction blocks are managed as task-local state. Nested transactions are fully supported, and are implemented using database savepoints.
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
File details
Details for the file databases-0.1.0.tar.gz
.
File metadata
- Download URL: databases-0.1.0.tar.gz
- Upload date:
- Size: 8.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/1.12.1 pkginfo/1.5.0.1 requests/2.21.0 setuptools/39.0.1 requests-toolbelt/0.9.1 tqdm/4.30.0 CPython/3.7.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 3c57bc1efdcab583cb7fd7a507b4b8dd089a85d633436002a7f30c8b7800e51f |
|
MD5 | 916165047e54ef45af6320fed8dc93f7 |
|
BLAKE2b-256 | 79e15f54816b80c5ec49917e76e29840c7977e5ae107a0f8cdbf491ad87d869a |