FastAPI 核心机制:分页参数的实现与最佳实践
title: FastAPI 核心机制:分页参数的实现与最佳实践
from fastapi import FastAPI, Query
from typing import List, Optional
app = FastAPI()
# 模拟数据库数据
fake_items_db = [{"item_name": f"Item {i}"} for i in range(100)]
@app.get("/items/")
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0)):
start = (page - 1) * page_size
end = start + page_size
items = fake_items_db[start:end]
total_items = len(fake_items_db)
total_pages = (total_items + page_size - 1) // page_size
return {
"items": items,
"page": page,
"page_size": page_size,
"total_items": total_items,
"total_pages": total_pages,
}
from fastapi import Query
@app.get("/items/")
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0, le=100)):
# 分页逻辑
pass
@app.get("/items/")
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0, le=100)):
# 分页逻辑
pass
total_pages = (total_items + page_size - 1) // page_size
from sqlalchemy.orm import Session
from fastapi import Depends
from .database import SessionLocal
def get_db():
db = SessionLocal()
try:
yield db
finally:
db.close()
@app.get("/items/")
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0, le=100),
db: Session = Depends(get_db)):
start = (page - 1) * page_size
items = db.query(Item).offset(start).limit(page_size).all()
total_items = db.query(Item).count()
total_pages = (total_items + page_size - 1) // page_size
return {
"items": items,
"page": page,
"page_size": page_size,
"total_items": total_items,
"total_pages": total_pages,
}
from sqlalchemy.sql import text
@app.get("/items/")
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0, le=100),
db: Session = Depends(get_db)):
start = (page - 1) * page_size
query = text("SELECT * FROM items LIMIT :limit OFFSET :offset")
items = db.execute(query, {"limit": page_size, "offset": start}).fetchall()
total_items = db.execute(text("SELECT COUNT(*) FROM items")).scalar()
total_pages = (total_items + page_size - 1) // page_size
return {
"items": items,
"page": page,
"page_size": page_size,
"total_items": total_items,
"total_pages": total_pages,
}
CREATE INDEX idx_items_created_at ON items (created_at);
from fastapi_cache import FastAPICache
from fastapi_cache.decorator import cache
@app.get("/items/")
@cache(expire=60)
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0, le=100)):
# 分页逻辑
pass
@app.get("/items/")
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0, le=100)):
# 分页逻辑
pass
from fastapi import HTTPException
@app.get("/items/")
async def read_items(page: int = Query(1, gt=0), page_size: int = Query(10, gt=0, le=100),
db: Session = Depends(get_db)):
try:
start = (page - 1) * page_size
items = db.query(Item).offset(start).limit(page_size).all()
total_items = db.query(Item).count()
total_pages = (total_items + page_size - 1) // page_size
return {
"items": items,
"page": page,
"page_size": page_size,
"total_items": total_items,
"total_pages": total_pages,
}
except Exception as e:
raise HTTPException(status_code=500, detail=str(e))
评论
发表评论