2

*.sdf在从本地 SQL Server Compact Edition 文件 ( )应用任何查询之前,我试图从数据库中获取架构。

到目前为止,当我知道架构时,我可以连接到数据库并执行查询。

我尝试过两次接近,但都失败了。

首先,我尝试使用

 import adodbapi.schema_table as DB_schema
 temp2 = DB_schema.names(connection_handler)

但这失败并出现以下错误:

raise AttributeError('在 ADO 连接对象中没有这样的属性 as="%s"' % item)
AttributeError: 在 ADO 连接对象中没有这样的属性 as="adoConn"

(这是参考指南中的简单解决方案)

connection_handler.get_table_names() #doesn't work

失败...

然后,我尝试了

sql_query_to_get_all_table_names_from_database = "SELECT Distinct TABLE_NAME FROM information_schema.TABLES"
cursor.execute(sql_query_to_get_all_table_names_from_database)

这也失败了,消息略有不同:

adodbapi.apibase.DatabaseError: (-2147352567, 'Exception occurred.', (0, u'Microsoft SQL Server Compact OLE DB Provider', u'Multiple-step OLE DB operation generated errors. 检查每个 OLE DB 状态值,如果可用. 没有完成任何工作。', None, 0, -2147217887), None)
命令:
SELECT Distinct TABLE_NAME FROM information_schema.TABLES

参数:
[]

在紧凑视图上执行相同的查询时可以正常工作。

任何想法都非常受欢迎。

还有其他方法吗?(我尝试过 odbc、SQL Server,但到目前为止还没有运气)

4

1 回答 1

0

使用 adodbapi 版本 2.6.0.7:

连接到数据库后,连接具有以下方法:

myconnection.get_table_names()

它返回架构,如参考指南中所述:

http://adodbapi.sourceforge.net/quick_reference.pdf

对我来说,这仅在更改连接器光标位置后才有效:

myconnection.connector.CursorLocation = 2

这会将光标位置更改为服务器端,这是我在这里找到的一个技巧:

如何使用 adodbapi 正确查询 sql ce 4.0 数据库文件?

于 2019-07-11T22:16:12.950 回答