栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

如何在SQLAlchemy中进行跨数据库查询联接?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

如何在SQLAlchemy中进行跨数据库查询联接?

您需要的是多部分架构名称。

__table_args__
如果您使用的是声明式,则可以使用并使用它来执行查询。由于您省略了表或模型定义,因此我将根据您的查询示例生成示例:

In [8]: class TableA(base):   ...:     __tablename__ = 'table_a'   ...:     __table_args__ = {   ...:         'schema': 'database1.schema1'   ...:     }   ...:     id = Column(Integer, primary_key=True)   ...:     field1 = Column(Integer)   ...:     field2 = Column(Integer)   ...:In [9]: class TableB(base):   ...:     __tablename__ = 'table_b'   ...:     __table_args__ = {   ...:         'schema': 'database2.schema1'   ...:     }   ...:     id = Column(Integer, primary_key=True)   ...:     field1 = Column(Integer)   ...:     field2 = Column(Integer)   ...:In [10]: q = session.query(TableA.field1, TableA.field2, TableB.field2).    ...:     join(TableB, TableA.field1 == TableB.field1)In [12]: q.statement.compile(dialect=mssql.dialect())Out[12]: <sqlalchemy.dialects.mssql.base.MSSQLCompiler at 0x7fa3886027b8>In [13]: print(_)SELECt database1.schema1.table_a.field1, database1.schema1.table_a.field2, database2.schema1.table_b.field2 FROM database1.schema1.table_a JOIN database2.schema1.table_b ON database1.schema1.table_a.field1 = database2.schema1.table_b.field1


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/610961.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号