pyodbc到远程sqlite数据库不工作但没有抛出错误

时间:2017-01-10 02:20:53

标签: python sqlite raspberry-pi odbc debian-based

我有一个运行OSMC的Raspberry Pi,这是Debian的媒体优化版本。这个Pi拥有一个SQLITE数据库,我想从我的Windows 7 PC上使用Python访问它。两台计算机都在同一个家庭网络上。

根据similar post的建议,我获得了SQLITE ODBC driver

我编写了以下代码来查询数据库。代码不会抛出任何异常,但它也不会返回任何数据。我做错了什么?

import pyodbc

def connectToDB():
    serverIP = '192.168.0.110' #raspberry pi on home network
    databaseName = 'pigarage.db'
    sql = 'DRIVER={SQLite3 ODBC Driver};SERVER=%s;DATABASE=%s;Trusted_connection=yes' % (serverIP, databaseName)
    conn = pyodbc.connect(sql)
    return conn

def runQuery(conn, sql):
    cursor = conn.cursor()
    cursor.execute(sql)
    result = list( cursor.fetchall() ) # list of tuples
    cursor.close()
    return result

if __name__ == '__main__':
    conn = connectToDB()
    print conn
    sql = 'select distinct state from GarageDoorState'
    print runQuery(conn, sql)
    conn.close()
    print 'completed successfully'

输出:

<pyodbc.Connection object at 0x035434E8>
[]
completed successfully

我注意到ODBC连接不需要任何类型的端口(不确定SQLite需要这个,因为它不是服务器数据库?),或者用户/ pwd等等。我想我只是对这个过程感到困惑,而我的设置是错误的。但后来我很疑惑为什么代码没有错误?

ODBC setup

1 个答案:

答案 0 :(得分:2)

SQLite数据库是一个文件,可以作为文件访问。

当您将数据库名称pigarage.db提供给驱动程序时,它将打开(或创建)具有该名称的文件。 (如果没有目录名,它将使用当前目录。)

要访问另一台计算机上的数据库,您需要使用网络文件系统(请参阅Samba),并确保它是correctly configured