python – sqlalchemy:关闭声明性多态连接?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – sqlalchemy:关闭声明性多态连接?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1914字,纯文字阅读大概需要3分钟。
内容图文
sqlalchemy中是否有一种方法可以在单个查询中关闭声明性的多态连接加载?大部分时间都很好,但我有:
class A(Base) :
discriminator = Column('type', mysql.INTEGER(1), index=True, nullable=False)
__mapper_args__ = { 'polymorphic_on' : discriminator }
id = Column(Integer, primary_key=True)
p = Column(Integer)
class B(A) :
__mapper_args__ = { 'polymorphic_identity' : 0 }
id = Column(Integer, primary_key=True)
x = Column(Integer)
class C(A) :
__mapper_args__ = { 'polymorphic_identity' : 1 }
id = Column(Integer, primary_key=True)
y = Column(String)
我想进行一个查询,以便得到所有A.ids,其中B.x> 10,如果A实际上是B,或者C.y ==’blah’,如果A实际上是C,则全部按p排序.
为了迭代地做,我只是从第一部分开始 – “如果A实际上是B,则获得所有A.id,其中B.x> 10.”所以我想我会从外部联接开始:
session.query(A.id).outerjoin((B, B.id == A.id)).filter(B.x > 10)
…除了似乎没有办法避免让外连接((B,B.id == A.id))子句生成A中所有内容与子选择中B中所有内容的完全连接.如果B没有从A继承,那么这种情况就不会发生,所以我认为这是多态声明代码生成.有没有办法把它关掉?或者强迫外部连接做我想做的事情?
我想要的是这样的:
select a.id from A a left outer join B b on b.id == a.id where b.x > 10
但取而代之的是:
select a.id from A a left outer join (select B.id, B.x, A.id from B inner join A on B.id == A.id)
……顺便说一句,如果不可能,那么后者效率会低于前者吗? sql引擎是否会实际执行内连接,还是会忽略它?
解决方法:
您可以尝试单独为每个子类构建查询,然后将它们组合在一起.在查询B.id时,SQLAlchemy隐式加入超类并返回A.id,因此对B.id和C.id选择联合仅返回单个列.
>>> b_query = session.query(B.id).filter(B.x > 10)
>>> c_query = session.query(C.id).filter(C.y == 'foo')
>>> print b_query.union(c_query)
SELECT anon_1."A_id" AS "anon_1_A_id"
FROM (SELECT "A".id AS "A_id"
FROM "A" JOIN "B" ON "A".id = "B".id
WHERE "B".x > ? UNION SELECT "A".id AS "A_id"
FROM "A" JOIN "C" ON "A".id = "C".id
WHERE "C".y = ?) AS anon_1
您仍然可以获得一个子选择,但只有一个“连接层” – 外部选择只是重命名该列.
内容总结
以上是互联网集市为您收集整理的python – sqlalchemy:关闭声明性多态连接?全部内容,希望文章能够帮你解决python – sqlalchemy:关闭声明性多态连接?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。