sqlalchemy查询oracle,使用SQLAlchemy的Oracle数据库架构

本文探讨了如何在 SQLAlchemy 中创建数据库表,并处理表间外键关系。建议检查是否已创建表,并展示了如何在定义外键时指定模式。通过使用模式值避免硬编码,可以更灵活地管理表之间的关联。同时,查看 SQLAlchemy 日志以了解执行的 SQL 查询,有助于调试和理解数据操作。
摘要由CSDN通过智能技术生成

步骤1:检查是否在db中创建了表。顺便说一句,您是如何创建这些表的?你有运行metadata.create_all()方法吗?

步骤2:尝试将架构名称添加到ForeignKey定义中:

Base = declarative_base()

SCHEMA = {'schema' : 'SIATDESV'}

class Pgdasd(Base):

__tablename__ = 'PGDASD'

__table_args__ = SCHEMA

PGDASD_00000_ID_DECLARACAO    = Column(String(17), primary_key = True)

class Pgdasd_01000(Base):

__tablename__ = 'pgdasd_01000'

__table_args__ = SCHEMA

PGDASD_00000_ID_DECLARACAO  = Column(String, ForeignKey('SIATDESV.PGDASD.PGDASD_00000_ID_DECLARACAO'))

PGDASD_01000_NRPAGTO        = Column(String, primary_key = True)

如果这样可以帮助您,还可以使代码使用模式值来避免对模式进行硬编码。

PGDASD_00000_ID_DECLARACAO  = Column(String, ForeignKey(SCHEMA['schema']+'.PGDASD.PGDASD_00000_ID_DECLARACAO'))

PS:无论如何,检查SQLAlchemy日志总是有用的,它会生成什么SQL查询。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值