我正在编写一个Python程序,使用PyODBC从Microsoft Access mdb文件中选择一些数据。
我需要发现几个不同表的列名。在SQL Server中,这可以通过使用像
这样的查询来完成SELECT c.name FROM sys.columns c, sys.tables t
WHERE c.object_id = t.object_id
AND t.name = tableName
但该查询在Access中不起作用。与
SELECT MSysObjects.Name FROM MSysObjects
WHERE (((MSysObjects.Flags)=0) AND ((MSysObjects.Type)=1))
ORDER BY MSysObjects.Name
我可以获取非链接表名列表,但MSysObject似乎不包含列名列表。
有没有办法使用SQL来获取Access数据库中表的列名?
答案 0 :(得分:6)
我无法找到SQL查询来完成此任务。但是,我确实发现PyODB有一个可以返回列列表的游标方法
# columns in table x
for row in cursor.columns(table='x'):
print row.column_name
答案 1 :(得分:0)
我不确定查询该版本MS-Access的限制,但我在其他类似情况下看到的解决方案是SELECT * FROM表LIMIT = 0(或1取决于)。然后,您可以从结果中收集返回的列名称。
答案 2 :(得分:0)
Python 3
To access by conlumn name
table_row = conn.execute(query)
for row in table_rows:
print (row.nameColumn)
To access by conlumn index
table_row = conn.execute(query)
for row in table_rows:
print (row[0])