sql-server - freetds 和 pyodbc 无法连接

标签 sql-server linux pyodbc freetds

我目前正在努力建立从 Linux 机器到 Microsoft SQL 服务器的连接。我已经在 Linux 机器上安装了 FreeTDS 和 pyodbc。

我已经设置了以下文件: /etc/freetds/freetds.conf

[sqlserver]
    host = <ip address>
    port = 1433
    tds version = 8.0
    client charset = UTF-8

~/.odbc.ini

[sqlserver]
Description     = FreeTDS MSSQL
Driver          = FreeTDS
Servername      = <same ip as above> 
Database        = Reports
TDS_Version     = 8.0

/etc/odbcinst.ini

[FreeTDS]
Description             = FreeTDS MSSQL
Driver                  = /usr/lib/x86_64-linux-gnu/odbc/libtdsodbc.so
Driver64                = /usr/lib/x86_64-linux-gnu/odbc/libtdsodbc.so
Setup                   = /usr/lib/x86_64-linux-gnu/odbc/libtdsS.so
Setup64                 = /usr/lib/x86_64-linux-gnu/odbc/libtdsS.so
UsageCount              = 1
CPTimeout               = 
CPTimeToLive            = 
DisableGetFunctions     = 
DontDLCLose             = 
ExFetchMapping          = 
Threading               = 
FakeUnicode             = 
IconvEncoding           = 
Trace                   = 
TraceFile               = 
TraceLibrary            = 

当我尝试运行 tsql -S sqlserver -U 用户名 -P 密码时,出现以下错误:

locale is "en_US.UTF-8"
locale charset is "UTF-8"
using default charset "UTF-8"
Msg 18452 (severity 14, state 1) from SYMPLECTIC03 Line 1:
    "Login failed. The login is from an untrusted domain and cannot be used with Windows authentication."
Error 20002 (severity 9):
    Adaptive Server connection failed
There was a problem connecting to the server

我还尝试在以下脚本中连接 pyodbc:

import pyodbc
try:
    cnxn = pyodbc.connect('DRIVER=FreeTDS;SERVER=same_ip_as_above;DATABASE=Reports;UID=myusername;PWD=mypassword')
except pyodbc.Error, err:
    print err

打印出以下错误:

('001', '[001] [nxDC[reD]SLSre]nbet onc odt ore (0) (SQLDriverConnect)')

不完全是最有用的错误消息。

尝试连接时我做错了什么吗?

作为旁注,我们的数据库需要 Windows 身份验证,而不是集成。 我可以通过 telnet 连接到主机,所以这也不是问题。

最佳答案

设置看起来不错。我有一个类似的东西在工作,在服务器升级到 NTLMv2 后就坏了.这在测试 tsql 时出现“...不受信任的域...”错误。 * detail here

我只需要在我的 freetds.conf 规范中包含 use ntlmv2 = yes

关于sql-server - freetds 和 pyodbc 无法连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26744692/

相关文章:

python - 使用python将excel文件中的数据导入SQL Server

python - PYODBC MS Access 插入错误 - 参数太少

python - Django 1.9升级 "Not Supported"问题

sql - 插入与插入

sql - 我需要在 T-SQL 数据透视查询中更改哪些内容才能实现此特定输出?

linux - 的 | grep -c' 和完整路径

linux - free如何计算已用内存?

sql - 在sql server中截断前导零

php 文件在实时服务器上显示错误

linux - chmod 777 的后果