Auto generate FastAPI endpoint by SqlAlchemy model for data access
pip install sqlalchemy-fastapi-endpoint-factoryOr
uv add --dev sqlalchemy-fastapi-endpoint-factoryInstall an example for a quick launch.
uv add fastapi sqlalchemy uvicorn# main.py
from fastapi import FastAPI
from sqlalchemy import Integer, Column, String, insert
from sqlalchemy_fastapi_endpoint_factory.main import make_endpoint
from sqlalchemy.orm import declarative_base
from sqlalchemy import create_engine
from sqlalchemy.orm import scoped_session, sessionmaker
Base = declarative_base()
class SimpleModel(Base):
    __tablename__ = "simple_model"
    id = Column(Integer, primary_key=True)
    username = Column(String)
    email = Column(String)
engine = create_engine("sqlite:///:memory:", connect_args={"check_same_thread": False})
connection = engine.connect()
ScopedSession = scoped_session(
    sessionmaker(autocommit=False, autoflush=False, bind=connection)
)
SimpleModel.__table__.create(bind=engine, checkfirst=True)
# Test data
TEST_DATA = [
    {"id": 1, "username": "user1", "email": "user1@example.com"},
    {"id": 2, "username": "user2", "email": "user2@example.com"},
    {"id": 3, "username": "user3", "email": "user3@example.com"},
    {"id": 4, "username": "admin", "email": "admin@example.com"},
    {"id": 5, "username": "test", "email": "test@example.com"},
]
with engine.begin() as conn:
    conn.execute(insert(SimpleModel), TEST_DATA)
def execute_query(query):
    with ScopedSession() as session:
        result = session.execute(query).mappings()
    return [dict(row) for row in result]
app = FastAPI()
app.add_api_route(
    "/simple/filter",
    endpoint=make_endpoint(SimpleModel, execute_query),
    methods=["POST"],
)uvicorn main:appVisit page in browser:

