91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

FastAPI中怎么使用ORM

小億
137
2024-05-11 11:29:57
欄目: 編程語言

在FastAPI中使用ORM,一般情況下會使用SQLAlchemy作為ORM框架。以下是一個簡單的示例:

  1. 首先,安裝SQLAlchemy和相應數據庫驅動:
pip install sqlalchemy
pip install databases
pip install psycopg2
  1. 創建一個數據庫連接:
from databases import Database
from sqlalchemy import create_engine

DATABASE_URL = "sqlite:///./test.db"
database = Database(DATABASE_URL)

# 創建數據庫引擎
engine = create_engine(DATABASE_URL)
  1. 創建一個基礎的模型類:
from sqlalchemy import Column, Integer, String
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class User(Base):
    __tablename__ = "users"
    
    id = Column(Integer, primary_key=True, index=True)
    name = Column(String)
    email = Column(String, unique=True)
  1. 創建數據庫表和連接數據庫:
from sqlalchemy.orm import sessionmaker

# 創建數據庫表
Base.metadata.create_all(engine)

# 創建Session
SessionLocal = sessionmaker(autocommit=False, autoflush=False, bind=engine)

# 創建一個函數來獲取數據庫會話
def get_db():
    db = SessionLocal()
    try:
        yield db
    finally:
        db.close()
  1. 在FastAPI中使用ORM:
from fastapi import FastAPI, Depends
from sqlalchemy.orm import Session
from models import User
from database import get_db

app = FastAPI()

# 創建用戶
@app.post("/users/")
def create_user(name: str, email: str, db: Session = Depends(get_db)):
    user = User(name=name, email=email)
    db.add(user)
    db.commit()
    db.refresh(user)
    return user

# 獲取用戶
@app.get("/users/{user_id}")
def get_user(user_id: int, db: Session = Depends(get_db)):
    return db.query(User).filter(User.id == user_id).first()

以上是一個簡單的FastAPI與SQLAlchemy ORM結合使用的示例。你可以根據自己的需求進一步擴展和優化。

0
年辖:市辖区| 海城市| 伊川县| 高雄县| 兰考县| 平遥县| 澄江县| 池州市| 定远县| 双桥区| 枣强县| 许昌市| 闸北区| 云浮市| 巴楚县| 米泉市| 靖江市| 巢湖市| 兴宁市| 宝兴县| 甘洛县| 万宁市| 惠水县| 呈贡县| 昌宁县| 南宁市| 武平县| 贵溪市| 通化市| 屏东市| 永城市| 安吉县| 夏河县| 大渡口区| 漠河县| 晋中市| 石河子市| 梁河县| 扶余县| 东宁县| 应城市|