sqlalchemy mysql ndb_python – 如何在SQLAlchemy中为MSSQL设置架构?

在尝试使用SQLAlchemy连接MSSQL数据库时,遇到了编程错误,指出'bar'对象无效。问题可能在于需要指定正确的架构。尽管可以在DBeaver中访问该架构,但在SQLAlchemy的连接字符串中加入架构参数导致了操作错误,登录失败。寻求解决方案来正确设置SQLAlchemy连接以包含架构信息。
摘要由CSDN通过智能技术生成

我目前这样做:

#!/usr/bin/env python

# 3rd party modules

from sqlalchemy import create_engine # requires pymssql

# local modules

from config import cfg

connection_string = 'mssql+pymssql://{user}:{password}@{host}:{port}/{db}'

engine = create_engine(connection_string

.format(host=cfg['db']['host'],

db=cfg['db']['database'],

user=cfg['db']['user'],

password=cfg['db']['password'],

port=cfg['db']['port'],

schema=cfg['db']['schema']))

with engine.begin() as conn:

sql = ('SELECT foo FROM bar;')

rows = conn.execute(sql)

print(rows)

但我明白了

File "/usr/local/lib/python3.5/dist-packages/sqlalchemy/engine/default.py", line 470, in do_execute

cursor.execute(statement, parameters)

File "pymssql.pyx", line 464, in pymssql.Cursor.execute (pymssql.c:7491)

sqlalchemy.exc.ProgrammingError: (pymssql.ProgrammingError) (208, b"Invalid object name 'bar'.DB-Lib error message 20018, severity 16:\nGeneral SQL Server error: Check messages from the SQL Server\n") [SQL: 'SELECT foo FROM bar;']

我认为问题是我必须使用架构exampleschema.我可以通过DBeaver使用相同的凭据访问架构exampleschema中带有列foo的表栏.

但是当我将/ {schema}添加到连接字符串时,我得到了

sqlalchemy.exc.OperationalError: (pymssql.OperationalError)

(18456,

b"Login failed for user 'exampleuser'.DB-Lib error message 20018,

severity 14:\nGeneral SQL Server error: Check messages from the SQL Server\nDB-Lib error message 20002,

severity 9:\nAdaptive Server connection failed (192.168.123.456:1433)\n")

如何设置架构?

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值