我在 FastAPI 中使用以下模型和架构。
型号
class Item(Base):
__tablename__ = "items"
id = Column(Integer, primary_key=True,index=True)
name = Column(String(80), nullable=False, unique=True,index=True)
price = Column(Float(precision=2), nullable=False)
description = Column(String(200))
store_id =Column(Integer,ForeignKey('stores.id'),nullable=False)
def __repr__(self):
return 'ItemModel(name=%s, price=%s,store_id=%s)' % (self.name, self.price,self.store_id)
class Store(Base):
__tablename__ = "stores"
id = Column(Integer, primary_key=True,index=True)
name = Column(String(80), nullable=False, unique=True)
items = relationship("Item",lazy="dynamic",primaryjoin="Store.id == Item.store_id")
def __repr__(self):
return 'Store(name=%s)' % self.name
架构
class ItemBase(BaseModel):
name: str
price : float
description: Optional[str] = None
store_id: int
class ItemCreate(ItemBase):
pass
class Item(ItemBase):
id: int
class Config:
orm_mode = True
class StoreBase(BaseModel):
name: str
class StoreCreate(StoreBase):
pass
class Store(StoreBase):
id: int
items: List[Item] = []
class Config:
orm_mode = True
我在数据库中创建了一个存储对象。当我尝试使用以下 API 获取数据库中存储的所有商店时。
@app.get('/stores', tags=["Store"],response_model=List[schemas.Store])
def get_all_stores(name: Optional[str] = None,db: Session = Depends(get_db)):
"""
Get all the Stores stored in database
"""
if name:
stores =[]
db_store = StoreRepo.fetch_by_name(db,name)
print(db_store)
stores.append(db_store)
return stores
else:
return StoreRepo.fetch_all(db)
[packages]
fastapi = "==0.68.1"
uvicorn = "==0.15.0"
sqlalchemy = "==1.4.23"
我收到以下异常
raise ValidationError(errors, field.type_)
pydantic.error_wrappers.ValidationError:商店有 1 个验证错误 响应 -> 0 -> 项目 值不是有效列表 (type=type_error.list)
如果我们从API中删除response_model=List[schemas.Store],那么它就可以正常工作。
任何帮助将不胜感激。
更新商店模型中的关系后,我能够解决上述问题。
items = relationship("Item",primaryjoin="Store.id == Item.store_id",cascade="all, delete-orphan")
分享它,以防它对某人有帮助。