【问题标题】:How to execute query saved in MS Access using pyodbc如何使用 pyodbc 执行保存在 MS Access 中的查询
【发布时间】:2023-11-14 11:19:01
【问题描述】:

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

【问题讨论】:

    标签: python sql ms-access ms-access-2007 pyodbc


    【解决方案1】:

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

    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()
    

    【讨论】:

    • 代码中缺少一行是import pyodbc。投票 - 因为它对我有用 ;-)
    • @Plirkee - 我添加了import 语句。谢谢。
    最近更新 更多