参数太少错误,同时没有使用参数占位符
Too few parameters error, while no parameters placeholders used
我正在尝试使用 PYODBC 在 Access 数据库中执行 SQL 查询,但出现以下错误:
pyodbc.Error: ('07002', '[07002] [Microsoft][ODBC Microsoft Access Driver]
Too few parameters. Expected 1. (-3010) (SQLExecDirectW)')
问题是我没有使用任何附加参数。这是代码:
access_con_string = r"Driver={};Dbq={};".format(driver, base)
cnn = pyodbc.connect(access_con_string)
db_cursor = cnn.cursor()
expression = """SELECT F_ARODES.ARODES_INT_NUM, F_ARODES.TEMP_ADRESS_FOREST,F_AROD_LAND_USE.ARODES_INT_NUM, F_ARODES.ARODES_TYP_CD
FROM F_ARODES LEFT JOIN F_AROD_LAND_USE ON F_ARODES.ARODES_INT_NUM = F_AROD_LAND_USE.ARODES_INT_NUM
WHERE (((F_AROD_LAND_USE.ARODES_INT_NUM) Is Null) AND ((F_ARODES.ARODES_TYP_CD)="wydziel") AND ((F_ARODES.TEMP_ACT_ADRESS)=True));"""
db_cursor.execute(expression)
查询本身,如果在 MS-Access 中使用则工作正常。此外,连接正常,因为其他查询已正确执行。
我做错了什么?
此类查询中的常量是有问题的 - 你永远不知道布尔值、字符串等的确切底层语法 - 即使它在 MS-Access 中工作,它在你使用的中间库中也可能不同。
最安全的方法是将它们提取为参数:
expression = """SELECT F_ARODES.ARODES_INT_NUM, F_ARODES.TEMP_ADRESS_FOREST,F_AROD_LAND_USE.ARODES_INT_NUM, F_ARODES.ARODES_TYP_CD FROM F_ARODES LEFT JOIN F_AROD_LAND_USE ON F_ARODES.ARODES_INT_NUM = F_AROD_LAND_USE.ARODES_INT_NUM WHERE (((F_AROD_LAND_USE.ARODES_INT_NUM) Is Null)
AND ((F_ARODES.ARODES_TYP_CD)=?) AND ((F_ARODES.TEMP_ACT_ADRESS)=?));"""
db_cursor.execute(expression, "wydziel", True)
我有一个类似的问题,我试图用 pyodbc 执行更新。在 Access 中执行时,查询工作正常,与使用应用程序时相同(它允许从应用程序内部进行一些查询)。但是当 运行 in python 和 pyodbc 相同的文本会抛出错误。我确定问题是双引号(OP 的查询也有一组)。当我用单引号替换它们时,查询开始工作。
这不起作用:
Update ApplicationStandards Set ShortCutKey = "I" Where ShortName = "ISO"
这样做:
Update ApplicationStandards Set ShortCutKey = 'I' Where ShortName = 'ISO'
我正在尝试使用 PYODBC 在 Access 数据库中执行 SQL 查询,但出现以下错误:
pyodbc.Error: ('07002', '[07002] [Microsoft][ODBC Microsoft Access Driver] Too few parameters. Expected 1. (-3010) (SQLExecDirectW)')
问题是我没有使用任何附加参数。这是代码:
access_con_string = r"Driver={};Dbq={};".format(driver, base)
cnn = pyodbc.connect(access_con_string)
db_cursor = cnn.cursor()
expression = """SELECT F_ARODES.ARODES_INT_NUM, F_ARODES.TEMP_ADRESS_FOREST,F_AROD_LAND_USE.ARODES_INT_NUM, F_ARODES.ARODES_TYP_CD
FROM F_ARODES LEFT JOIN F_AROD_LAND_USE ON F_ARODES.ARODES_INT_NUM = F_AROD_LAND_USE.ARODES_INT_NUM
WHERE (((F_AROD_LAND_USE.ARODES_INT_NUM) Is Null) AND ((F_ARODES.ARODES_TYP_CD)="wydziel") AND ((F_ARODES.TEMP_ACT_ADRESS)=True));"""
db_cursor.execute(expression)
查询本身,如果在 MS-Access 中使用则工作正常。此外,连接正常,因为其他查询已正确执行。 我做错了什么?
此类查询中的常量是有问题的 - 你永远不知道布尔值、字符串等的确切底层语法 - 即使它在 MS-Access 中工作,它在你使用的中间库中也可能不同。
最安全的方法是将它们提取为参数:
expression = """SELECT F_ARODES.ARODES_INT_NUM, F_ARODES.TEMP_ADRESS_FOREST,F_AROD_LAND_USE.ARODES_INT_NUM, F_ARODES.ARODES_TYP_CD FROM F_ARODES LEFT JOIN F_AROD_LAND_USE ON F_ARODES.ARODES_INT_NUM = F_AROD_LAND_USE.ARODES_INT_NUM WHERE (((F_AROD_LAND_USE.ARODES_INT_NUM) Is Null)
AND ((F_ARODES.ARODES_TYP_CD)=?) AND ((F_ARODES.TEMP_ACT_ADRESS)=?));"""
db_cursor.execute(expression, "wydziel", True)
我有一个类似的问题,我试图用 pyodbc 执行更新。在 Access 中执行时,查询工作正常,与使用应用程序时相同(它允许从应用程序内部进行一些查询)。但是当 运行 in python 和 pyodbc 相同的文本会抛出错误。我确定问题是双引号(OP 的查询也有一组)。当我用单引号替换它们时,查询开始工作。
这不起作用:
Update ApplicationStandards Set ShortCutKey = "I" Where ShortName = "ISO"
这样做:
Update ApplicationStandards Set ShortCutKey = 'I' Where ShortName = 'ISO'