Я пытаюсь запустить 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, а также не могу переключиться на другую базу данных.