我的机器上有一个名为“Test”的本地数据库,其中包含一个名为“Tags”的表。我可以通过 SQL Server management studio 2008 访问这个数据库并从这个表中查询。
但是,在使用 pyodbc 时,我一直遇到问题。
使用这个:
conn = pyodbc.connect('DRIVER={SQL Server};SERVER=localhost:1433;DATABASE=Test')
产生错误:
pyodbc.Error: ('08001', '[08001] [Microsoft][ODBC SQL Server Driver][DBNETLIB]Invalid connection. (14) (SQLDriverConnectW); [01000] [Microsoft][ODBC SQL Server Driver][DBNETLIB]ConnectionOpen (Invalid Instance()). (14)')
(有或没有指定端口)
尝试替代连接字符串:
conn = pyodbc.connect('DRIVER={SQL Server};SERVER=localhost\Test,1433')
不会产生错误,但随后:
cur = conn.cursor()
cur.execute("SELECT * FROM Tags")
产生错误:
pyodbc.ProgrammingError: ('42S02', "[42S02] [Microsoft][ODBC SQL Server Driver][SQL Server]Invalid object name 'Tags'. (208) (SQLExecDirectW)")
为什么会这样?