Как подключиться к серверу Microsoft SQL с кода Python? - PullRequest
0 голосов
/ 19 июня 2020

Я пытаюсь запустить Microsoft SQL Server в Docker и подключиться к нему через Python с pyodbc.

Я работаю впервые с этой базой данных и сводит меня с ума, потому что он убивал мою систему 5 раз подряд, и я не понимаю, как настроить простое соединение.

Как я запускаю базу данных:

docker run -e 'ACCEPT_EULA=Y' -e 'SA_PASSWORD=mySecretPassword1234567890' -p 1433:1433 -d mcr.microsoft.com/mssql/server:2017-latest

Я использую этот код для подключения:

import pyodbc

conn_str = (
    r"Driver={ODBC Driver 17 for SQL Server};"
    r"Server=127.0.0.1;"
    r"Database=testdb;"
    r"UID=sa;"
    r"PWD=mySecretPassword1234567890;"
    r"Trusted_Connection=yes;"
)
conn = pyodbc.connect(conn_str)

odbcinst подробности:

$ odbcinst -j
unixODBC 2.3.7
DRIVERS............: /usr/local/etc/odbcinst.ini
SYSTEM DATA SOURCES: /usr/local/etc/odbc.ini
FILE DATA SOURCES..: /usr/local/etc/ODBCDataSources
USER DATA SOURCES..: /Users/dmytro/.odbc.ini
SQLULEN Size.......: 8
SQLLEN Size........: 8
SQLSETPOSIROW Size.: 8

Трассировка отладки из ODB C драйвер:

[ODBC][23857][1592579186.233946][__handles.c][460]
        Exit:[SQL_SUCCESS]
            Environment = 0x7fc1a9973e00
[ODBC][23857][1592579186.233981][SQLSetEnvAttr.c][189]
        Entry:
            Environment = 0x7fc1a9973e00
            Attribute = SQL_ATTR_ODBC_VERSION
            Value = 0x3
            StrLen = 4
[ODBC][23857][1592579186.234005][SQLSetEnvAttr.c][381]
        Exit:[SQL_SUCCESS]
[ODBC][23857][1592579186.234024][SQLAllocHandle.c][377]
        Entry:
            Handle Type = 2
            Input Handle = 0x7fc1a9973e00
[ODBC][23857][1592579186.234044][SQLAllocHandle.c][493]
        Exit:[SQL_SUCCESS]
            Output Handle = 0x7fc1a997ae00
[ODBC][23857][1592579186.234321][SQLDriverConnectW.c][290]
        Entry:
            Connection = 0x7fc1a997ae00
            Window Hdl = 0x0
            Str In = [Driver={ODBC Driver 17 for SQL Server};Server=127.0.0.1;Database=testdb;UID=sa;PWD=mySecretPassword1234567890;Trusted_Connectio...][length = 133 (SQL_NTS)]
            Str Out = 0x0
            Str Out Max = 0
            Str Out Ptr = 0x0
            Completion = 0
        UNICODE Using encoding ASCII 'UTF-8' and UNICODE 'UCS-2-INTERNAL'

[ODBC][23857][1592579186.234896][SQLConnect.c][1138]Can't open lib 'ODBC Driver 17 for SQL Server' : file not found
[ODBC][23857][1592579186.234929][SQLDriverConnect.c][748]
        Entry:
            Connection = 0x7fc1a997ae00
            Window Hdl = 0x0
            Str In = [Driver={ODBC Driver 17 for SQL Server};Server=127.0.0.1;Database=testdb;UID=sa;PWD=**************************;Trusted_Connection...][length = 133 (SQL_NTS)]
            Str Out = 0x7ffeef507600
            Str Out Max = 2048
            Str Out Ptr = 0x0
            Completion = 0
[ODBC][23857][1592579186.235105][SQLConnect.c][1138]Can't open lib 'ODBC Driver 17 for SQL Server' : file not found
[ODBC][23857][1592579186.235134][SQLGetDiagRecW.c][535]
        Entry:
            Connection = 0x7fc1a997ae00
            Rec Number = 1
            SQLState = 0x7ffeef5099a4
            Native = 0x7ffeef509194
            Message Text = 0x7ffeef5091a0
            Buffer Length = 1023
            Text Len Ptr = 0x7ffeef50919e
[ODBC][23857][1592579186.235160][SQLGetDiagRecW.c][596]
        Exit:[SQL_SUCCESS]
            SQLState = [01000]
            Native = 0x7ffeef509194 -> 0
            Message Text = [[unixODBC][Driver Manager]Can't open lib 'ODBC Driver 17 for SQL Server' : file not found]
[ODBC][23857][1592579186.235205][SQLFreeHandle.c][290]
        Entry:
            Handle Type = 2
            Input Handle = 0x7fc1a997ae00
[ODBC][23857][1592579186.235224][SQLFreeHandle.c][339]
        Exit:[SQL_SUCCESS]

Я читал документы и искал ответы в StackOverflow, но пока не могу его получить. Как я могу отладить его дальше?

Важно: я не могу переключиться с подхода Docker к запуску Microsoft SQL Server, а также не могу переключиться на другую базу данных.

Ответы [ 2 ]

1 голос
/ 22 июня 2020

Выяснилось, что проблема в драйверах. pyodbc.drivers() вернул пустой список. Для связи между Micorosft SQL Server и Python вам потребуется дополнительный ODB C уровень драйвера

Спасибо @abestrad, который указал на это.

0 голосов
/ 19 июня 2020

Попробуйте следующее:

import pyodbc

conn_str = (
    r"Driver={ODBC Driver 17 for SQL Server};"
    r"Server=host.docker.internal;"
    r"Database=testdb;"
    r"UID=sa;"
    r"PWD=mySecretPassword1234567890;"
    r"Trusted_Connection=yes;"
)
conn = pyodbc.connect(conn_str)
...