一尘不染

Linux python3-无法打开lib'SQL Server'

linux

我正在尝试连接到Microsoft Azure SQL服务器数据库。

这就是我尝试连接的方式:

 conn = pyodbc.connect('DRIVER={SQL Server};SERVER=%s' % (self.config.get("Sql", "DataSource")),
                        user= self.config.get("Sql", "UserId"),
                        password=self.config.get("Sql", "Password"),
                        database=self.config.get("Sql", "Catalog"))

执行此行时出现错误。错误:

pyodbc.Error: ('01000', "[01000] [unixODBC][Driver Manager]Can't open lib 'SQL Server' : file not found (0) (SQLDriverConnect)")

不知道为什么会这样,知道吗?


阅读 374

收藏
2020-06-07

共1个答案

一尘不染

我还建议您安装ODBC驱动程序,然后尝试使用pyodbc。我假设您使用的是Ubuntu 15.04+计算机。

要安装ODBC驱动程序,请按照以下说明进行操作:

sudo su
wget https://gallery.technet.microsoft.com/ODBC-Driver-13-for-Ubuntu-b87369f0/file/154097/2/installodbc.sh
sh installodbc.sh

完成后,请使用pip安装pyodbc并尝试以下脚本:

import pyodbc
server = 'tcp:myserver.database.windows.net'
database = 'mydb'
username = 'myusername'
password = 'mypassword'
cnxn = pyodbc.connect('DRIVER={ODBC Driver 13 for SQL Server};SERVER='+server+';DATABASE='+database+';UID='+username+';PWD='+ password)
cursor = cnxn.cursor()
cursor.execute("SELECT @@version;")
row = cursor.fetchone()
while row:
    print row
    row = cursor.fetchone()

让我知道怎么回事。

欢呼,
见面

2020-06-07