这是我的情景.我有一个可以与一个或多个部门相关联的客户模型.这些分区静态存储在数据库中,并且可以与一个或多个客户相关联,因此需要我建模多对多关系.有一个REST API路由,形式为/ API / v1 / customers / 123 / division,其中我以分区ID列表的形式POST JSON数据,{‘division_IDs’:[1,2,3,4]}.在这种情况下(实际使用可能相当于20个分区ID,我将需要发出一个查询来获取客户(ID 123)以及4个查询以获取分区.
既然我知道要插入的分区的ID,我可以强制sqlAlchemy只使用ID而不是获取对象吗?
sqlAlchemy可以做类似的事吗?
解决方法 如果我正确理解你的问题,是的,你可以通过在关系中使用lazy =“dynamic”来实现. Docs:A key feature to enable management of a large collection is the so-called “dynamic” relationship. This is an optional form of relationship() which returns a query object in place of a collection when accessed. filter() criterion may be applIEd as well as limits and offsets,either explicitly or via array slices:
示例表:
@H_301_31@class Parent(Base): __tablename__ = 'parent' ID = Column(Integer,primary_key=True) children = relationship("Child",lazy="dynamic")class Child(Base): __tablename__ = 'child' ID = Column(Integer,primary_key=True) parent_ID = Column(Integer,ForeignKey('parent.ID'))加载Parent对象时,不会加载子对象;相反,将在其位置加载query对象,如果需要,可以使用它来访问子对象.
@H_301_31@p = session.query(Parent).first() # children will not be loaded hereprint(type(p.children)) # <class 'sqlalchemy.orm.dynamic.Appenderquery'>all_children = p.children.all() # conduct a query on the children query objectprint(all_children) # [<__main__.Child object at 0x10ba3f908>,<__main__.Child object at 0x10ba3f978>] 总结以上是内存溢出为你收集整理的python – SQLAlchemy可以在不查询数据库的情况下填充外键关系吗?全部内容,希望文章能够帮你解决python – SQLAlchemy可以在不查询数据库的情况下填充外键关系吗?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)