如何解决使用fastapi-contrib的FastApi分页错误
我正在尝试将分页添加到我的fastapi项目中。所以我决定使用这个:
我在那儿遵循相同的示例,但是由于某种原因,我遇到了这个错误:
type object 'MOrdenesTrabajo' has no attribute 'count'
这是我的代码,谢谢您的帮助!
路线
@router.get("/ordenes-trabajo")
async def read_ot(pagination: Pagination = Depends(),db: Session =Depends(get_db)):
filter_kwargs = {}
return await pagination.paginate(serializer_class=OtSerializer.MOrdenesTrabajo,**filter_kwargs)
热缩模型
class MOrdenesTrabajo(ModelSerializer):
class Meta:
model = OT # <---Model below
Sqlalchemy模型
class MOrdenesTrabajo(Base):
__tablename__ = 'M_ordenesTrabajos'
idordenesTrabajos = Column(Integer,primary_key=True)
fecCreacion = Column(Date)
fecModificacion = Column(Date)
estado = Column(Integer)
descripcion = Column(Text)
nombre = Column(String(100))
documento = Column(Text)
fechaOrden = Column(Date)
numero = Column(Text)
ot_padre = Column(Integer)
data = Column(JSON)
解决方法
我认为您应该使用sqlalchemy-filters。我在FastAPI项目中使用它进行分页,它按预期工作。 我的分页代码如下:
# pagination
num_of_pages = 0
total_results = 0
if skip and limit:
results,pagination = apply_pagination(
results,page_number=skip,page_size=limit
)
num_of_pages = pagination.num_pages
total_results = pagination.total_results
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。