Connect to SQL Server instance using pymssql
Asked Answered
A

3

11

I'm attempting to connect to a SQL Server instance from a Windows box using pymssql (version 2.0.0b1-dev-20111019 with Python 2.7.1). I've tried the most basic approach from the console:

import pymssql
c = pymssql.connect(host = r'servername\instance',
                    user = 'username',
                    password = 'userpassword')

In response to this, I get the very helpful error: InterfaceError: Connection to the database failed for an unknown reason.

I am reasonably confident that the connection information is correct, as it works when I use adodbapi, with the following commands:

import adodbapi
c = adodbapi.connect(r'Provider=sqloledb;Data Source=servername\instance;User ID=username;password=userpassword;'
c.close

I've tried adding the port number to the host parameter, with the same result. Does anyone have a suggestion on how to go about resolving this issue?


Incidentally, I've read the responses at "Unable to connect to SQL Server via pymssql". The OP eventually resolved his issue by correctly configuring FreeTDS, which, from what I can tell, is not used by pymssql on Windows.


Based on @cha0site's recommendation, I have tried using just the hostname, rather than the hostname and instance. This resulted in the same error, but it seemed to take longer to generate the error (though the traceback still indicates the same line). The reason I have been specifying the instance is that I was not able to connect using SSMS unless I specified the instance, so I assumed that it would be necessary for other connections.


I've now also tried pymssql.connect(host='servername', user='username', password='userpassword', database='instance') with the same result (based on @Sid's comment). Based on the pymssql documentation, I believe the database parameter is used to specify the initial database that the user is to be connected to, rather than the instance.

Just to clarify, "instance" is the name provided during installation of SQL Server, not a database within that installation. It occurs to me that it's possible that pymssql does not support this notation, so I will look into re-configuring the SQL Server instance so that it is not required.


I've now re-installed SQL Server as a default instance, rather than a named instance, which allows me to connect without specifying the instance name. adodbapi still works (without /instance), but pymssql still returns the same error. I've also removed and re-installed pymssql from a freshly downloaded archive (still the same version).

Abattoir answered 6/2, 2012 at 18:14 Comment(2)
I have rolled back the edits made to this question. I feel that those edits primarily made stylistic changes (which I could live with, but felt unnecessary), but also removed salient details.Abattoir
That's not about you, but about the future Stack Overflow users. Most people don't speak English as their native language and my stylistic changes are key for learning better grammar. Plus the readability of your text is bad. Nevertheless, I got my points for the edit. Thanks for getting back to me.Copyhold
C
0

Check your freetds.conf file and see if you have set the port 1219., then check again the connection:

DB = pymssql.connect(host='DB',user='youruser',password='yourpwd',database='yourDBname')

Edit: example of my freetds.conf file Python:

host = 'IP'
port = 1219
Crabtree answered 12/4, 2012 at 10:44 Comment(0)
C
0

To specify host=servername\instance or server=servername\instance, the SQL Server Browser service must be on the SQL Server machine.

Copyhold answered 20/12, 2020 at 3:24 Comment(1)
This is an 8-year old question and I know longer have the environment to test this answer. However, this answer foes nothing to explain my the same configuration worked in adodbapi, but not in pymssql . If this explanation was the root of the problem, neither library should have been able to connect.Abattoir
C
0

Here can work on my workspace pymssql version: 2.2.8 python verison: 3.11

conn = pymssql.connect(host=r'10.0.1.29:60001\sql2019', user='sa', password='sa', charset='UTF-8', atabase=r'database1', tds_version=r'7.0')

the tds_version should be set 7.0 if you used pymssql 2.2.8. you can have a try other tds_version(7.4,7.3,7.2,7.1,7.0...) if you still encountered issue

you can add addtional version informaiton and debug code

print('pymssql version: ', pymssql.__version__)
print('get_dbversion: ', pymssql.get_dbversion())
print('version_info: ', pymssql.version_info())
os.environ['TDSDUMP'] = 'stdout'
Coughlin answered 7/9, 2023 at 3:43 Comment(0)

© 2022 - 2025 — McMap. All rights reserved.