gpt4 book ai didi

python - 如何使用 pyodbc 执行保存在 MS Access 中的查询

转载 作者:太空宇宙 更新时间:2023-11-04 10:17:13 26 4
gpt4 key购买 nike

网上有很多关于如何使用 pyodbc 在 MS Access 2007 中运行查询的提示,但所有这些查询都是在 Python 脚本本身中编码的。我想使用 pyodbc 调用已保存在 MS Access 中的查询。我该怎么做?

最佳答案

如果在 Access 中保存的查询是一个没有参数的简单 SELECT 查询,那么 Access ODBC 驱动程序会将其公开为一个 View ,因此您需要做的就是像使用表一样使用查询名称:

import pyodbc
connStr = (
r"Driver={Microsoft Access Driver (*.mdb, *.accdb)};"
r"DBQ=C:\Users\Public\Database1.accdb;"
)
cnxn = pyodbc.connect(connStr)
sql = """\
SELECT * FROM mySavedSelectQueryInAccess
"""
crsr = cnxn.execute(sql)
for row in crsr:
print(row)
crsr.close()
cnxn.close()

如果查询是其他类型的查询(例如,带参数的 SELECT、INSERT、UPDATE 等),则 Access ODBC 驱动程序会将它们公开为存储过程,因此您需要使用 ODBC {CALL 。 ..} 语法,如

import pyodbc
connStr = (
r"Driver={Microsoft Access Driver (*.mdb, *.accdb)};"
r"DBQ=C:\Users\Public\Database1.accdb;"
)
cnxn = pyodbc.connect(connStr)
sql = """\
{CALL mySavedUpdateQueryInAccess}
"""
crsr = cnxn.execute(sql)
cnxn.commit()
crsr.close()
cnxn.close()

关于python - 如何使用 pyodbc 执行保存在 MS Access 中的查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34614070/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com