Python library to easily add pagination on top of DB queries. Supports SQLAlchemy and SQLModel ORMs. This returns a base64 encoded string that can be used to paginate through the results.
Install the latest version from PyPi
pip install sqlpage
Now configure your ORM and then simply call the paginate
function to get the paginated results.
result: PageData = paginate(session, query, page_size=100)
This will return a PageData
object that will have the following structure
{
"next_page_token": "base64 encoded string",
"items":[
...
...
...
]
}
For end-to-end implementation, refer to testing
Before using the paginate
function, you need to configure the ORM. As SQLAlchemy and SQLModel uses different
ORMs, you need to configure them separately. This is a one-time setup and you would have already taken this while
configuring the ORM when creating the DB models.
Create your table model
Base = declarative_base()
class User(Base):
__tablename__ = 'user'
id = Column(Integer, primary_key=True)
username = Column(String)
email = Column(String)
Then create a DB session and call
engine = create_engine(f"sqlite:///{DATABASE_NAME}", echo=False)
Base.metadata.create_all(engine)
SessionSqlAlchemy = sessionmaker(bind=engine)
session = SessionSqlAlchemy()
query = session.query(TestTable)
result: PageData = paginate(session, query, page_size=100)
Create your table model
class User(SQLModel, table=True):
__tablename__ = 'user'
id: int = Field(primary_key=True)
username: str = Field(default=None)
email: str = Field(default=None)
Then create a DB session and call
engine = create_engine(f"sqlite:///{DATABASE_NAME}", echo=False)
Base.metadata.create_all(engine)
with Session(engine) as session:
query = session.query(TestTable)
result: PageData = paginate(session, query, page_size=100)
Feel free to open an issues under the Issues
tab. Contributions are welcome and appreciated.