Using the database API¶
Safir-based applications that use a SQL database can use Safir to initialize that database and acquire a database session. Safir-based applications that use FastAPI can also use the Safir-provided FastAPI dependency to manage per-request database sessions. The Safir database support is based on SQLAlchemy and assumes use of PostgreSQL (possibly via Cloud SQL) as the underlying database.
Safir is an asyncio framework and requires using SQLAlchemy’s asyncio API. Safir uses the asyncpg PostgreSQL database driver by default for PostgreSQL databases and the asyncmy MySQL database driver by default for MySQL databases. PostgreSQL is strongly preferred and should be used where possible.
Database support in Safir is optional.
To use it, depend on safir[db] in your pip requirements.
When using Safir with MySQL, you will also need to depend on asyncmy.
Also see Configuring PostgreSQL and Redis DSNs for Pydantic types that help with configuring the PostgreSQL DSN.