LIKE查询的结果不一致:pyodbc与Access

2024-10-06 08:41:49 发布

您现在位置:Python中文网/ 问答频道 /正文

我得到了一堆查询,它们应该作为Python脚本的一部分在Access数据库中执行。不幸的是,直接在msaccess中使用的查询给出了一些输出记录,在Python脚本中没有返回任何结果(也没有错误)。与数据库和一般语法的连接应该很好,因为简单的查询(比如从表中选择一列)就可以正常工作了。下面是一个包含以下给定查询之一的代码:

import pyodbc

baza = r"C:\base.mdb"
driver = "{Microsoft Access Driver (*.mdb, *.accdb)}"

access_con_string = r"Driver={};Dbq={};".format(driver, baza)
cnn = pyodbc.connect(access_con_string)
db_cursor = cnn.cursor()

expression = """SELECT F_PARCEL.PARCEL_NR, F_PARCEL_LAND_USE.AREA_USE_CD, F_PARCEL_LAND_USE.SOIL_QUALITY_CD, F_ARODES.TEMP_ADRESS_FOREST, F_SUBAREA.AREA_TYPE_CD, F_AROD_LAND_USE.AROD_LAND_USE_AREA, F_PARCEL.COUNTY_CD, F_PARCEL.DISTRICT_CD, F_PARCEL.MUNICIPALITY_CD, F_PARCEL.COMMUNITY_CD, F_SUBAREA.SUB_AREA
FROM F_PARCEL INNER JOIN (F_PARCEL_LAND_USE INNER JOIN ((F_ARODES INNER JOIN F_AROD_LAND_USE ON F_ARODES.ARODES_INT_NUM = F_AROD_LAND_USE.ARODES_INT_NUM) INNER JOIN F_SUBAREA ON F_ARODES.ARODES_INT_NUM = F_SUBAREA.ARODES_INT_NUM) ON (F_PARCEL_LAND_USE.SHAPE_NR = F_AROD_LAND_USE.SHAPE_NR) AND (F_PARCEL_LAND_USE.PARCEL_INT_NUM = F_AROD_LAND_USE.PARCEL_INT_NUM)) ON F_PARCEL.PARCEL_INT_NUM = F_PARCEL_LAND_USE.PARCEL_INT_NUM
WHERE (((F_ARODES.TEMP_ADRESS_FOREST) Like ?) AND ((F_AROD_LAND_USE.AROD_LAND_USE_AREA)<?) AND ((F_ARODES.TEMP_ACT_ADRESS)= ?))
ORDER BY F_PARCEL.PARCEL_NR, F_PARCEL_LAND_USE.SHAPE_NR;"""

rows = db_cursor.execute(expression, ("14-17-2-03*", 0.0049, True)).fetchall()

for row in rows:
    print row

cnn.close()

我知道这些查询是从msaccess中的querybuilder生成的,所以我想知道这可能会导致差异,但另一方面,这仍然是Access数据库。在

不管怎么说,问题似乎出在SQL中,所以我想知道哪些元素可能会导致直接在MS Access中执行的查询和通过pyodbc连接执行的查询之间的输出不同?在


Tags: accessuseoncdareanrnumint
1条回答
网友
1楼 · 发布于 2024-10-06 08:41:49

在Access中运行的查询和从外部应用程序运行的查询之间存在类似通配符的差异,这会让您感到困惑。在

在Access内部运行查询时,需要使用星号作为通配符:"14-17-2-03*"。在

从外部应用程序(如Python应用程序)运行查询时,需要使用百分号作为通配符:"14-17-2-03%"。在

相关问题 更多 >